codevs1026 逃跑的拉爾夫,廣搜的勝利

2021-07-04 19:57:32 字數 2454 閱讀 9661

1026 逃跑的拉爾夫

時間限制: 1 s

空間限制: 128000 kb

題目等級 : ** gold

題解 檢視執行結果

題目描述 description

年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。

那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。

編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。

小鎮的地圖是矩形的,上面的符號用來標明哪兒可以行車哪兒不行。「.」表示小鎮上那塊地方是可以行車的,而符號「x」表示此處不能行車。拉爾夫所開小車的初始位置用字元的「*」表示,且汽車能從初始位置通過。

汽車能向四個方向移動:向北(向上),向南(向下),向西(向左),向東(向右)。

輸入描述 input description

輸入檔案的第一行包含兩個用空格隔開的自然數r和c,1≤r≤50,1≤c≤50,分別表示小鎮地圖中的行數和列數。

以下的r行中每行都包含一組c個符號(「.」或「x」或「*」)用來描述地圖上相應的部位。

接下來的第r+2行包含乙個自然數n,1≤n≤1000,表示一組方向的長度。

接下來的n行幅行包含下述單詞中的任乙個:north(北)、south(南)、west(西)和east(東),表示汽車移動的方向,任何兩個連續的方向都不相同。

輸出描述 output description

輸出檔案應包含用r行表示的小鎮的地圖(象輸入檔案中一樣),字元「*」應該僅用來表示汽車最終可能出現的位置。

樣例輸入 sample input

4 5.x…

…*xx.x..

north

west

south

樣例輸出 sample output

…..x..

..xx.x..

隨便說說

首先,po主心情是非常激動的(≧▽≦)/,因為這個題目po主與xyx同學一起討論除錯了很久,成功拉低了這道題ac率近1個百分點,po主一直在re從未被超越,只能過三個點,後來看到網上的討論說是要進行判重,xyx大爺改完以後就乙個點沒過,我在xyx大爺的幫助下(我剛開始認為我的方法不需要判重)成功a掉了這道題目,so~~~

——————————————我是分割線———————————————

解析:

這道題是一道比較經典的bfs題目,具體的思路就是從起點開始進行搜尋,把能走的點入隊,不斷進行,最終找出步數達到指定數目且合法的點即可,po主太弱了不會用cpp自帶佇列所以只能手打╮(╯▽╰)╭,最終程式怒打近100行,不過要比以前寫的那個150行+還沒過的四子連棋好。

**:

#include

#include

using

namespace

std;

int r,c,a[101][101],n,xx,yy,b[1000001][2],head,tail;//陣列開的很大因為怕re,這個記憶體基本夠的,不用擔心

bool flag[51][51][1001];//flag[x][y][z]用來表示座標為(x,y)的點在第z步時是否走過,用來作判重工作,不加這個會re很多

struct os

team[1000001];//佇列,沒什麼好說的,x,y指座標,bs指當前步數

string s[1001];

char ch;

main()

} //通過數字矩陣存放地圖,記錄起點座標,並且可以將起點變為*(可走)

scanf("%d",&n);

team[1].x=xx;

team[1].y=yy;

team[1].bs=1;

head=1;

tail=1;

for (int i=1;i<=n;i++)

cin>>s[i];//讀入指令

int tt=0;

while (head<=tail)

//若當前步數已達到目標,則佇列中剩餘的點都是可走的點,將其匯出

else

else

if (s[team[head].bs]=="south")

while (xx1][yy]!=-1&&flag[xx+1][yy][team[head].bs]==false)

else

if (s[team[head].bs]=="west")

while (yy>1&&a[xx][yy-1]!=-1&&flag[xx][yy-1][team[head].bs]==false)

else

if (s[team[head].bs]=="east")

while (yy1]!=-1&&flag[xx][yy+1][team[head].bs]==false)

}head++;

}for (int i=1;i<=r;i++)

}

CodeVs 1026 逃跑的拉爾夫

題目描述 年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。小鎮的地圖是矩形...

Codevs 1026 逃跑的拉爾夫

時間限制 1 s 空間限制 128000 kb 題目等級 gold 題目描述 description 那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。小鎮的地圖是矩形的,上面的符號用來標明哪兒...

codevs 1026 逃跑的拉爾夫

題目描述 description 年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能...