1026 逃跑的拉爾夫

2021-09-07 10:44:37 字數 3551 閱讀 6291

時間限制: 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...

...*x

x.x..

north

west

south

樣例輸出

sample output

*x*..

*.*.x

x.x..

資料範圍及提示

data size & hint

分類標籤 tags 點此展開

好吧我承認這道題我想複雜了。。。

無奈bfs水平實在太弱沒寫出來

只能用dfs

1     #include2     #include3

using

namespace

std;

4const

int max_n = 51

; 5

const

int max_m = 1001

; 6

intr, c, n;

7int

x, y;

8int turn[max_m]; //

移動方向 ,turn[t] 表示 第t個方向

9int m[max_n][max_n]; //

以0,1儲存原地圖,方便判斷

10char a[max_n][max_n]; //

以字元儲存行駛後的地圖,方便輸出

11int vis[max_n][max_n][max_m]; //

vis[x][y][t] 表示 從點(x,y)往第t個方向(turn[t])移動

12void dfs(int x, int y, int

t)

13

21if (turn[t] == 1) //

北(上)

22

29}

30if (turn[t] == 2) //

南(下)

31

38}

39if (turn[t] == 3) //

西(左)

40

47}

48if (turn[t] == 4) //

東(右)

49

56}

57}

58int

main()

59

76}

77}

78 cin>>n;

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

80

88 dfs(x, y, 1

);

89for (i = 1; i <= r; i++)

90

96return

0;

97 }

錯誤的bfs

1 #include2 #include3 #include4 #include5

using

namespace

std;

6const

int maxn=1001;7

const

int maxn=0x7fffffff;8

intmap[maxn][maxn];

9int

vis[maxn][maxn];

10int

fx[maxn];

11int

n,m;

12 queuexzb;

13 queueyzb;

14int

p;15

void bfs(int x,int

y)16

37else

3843}44

xzb.pop();

45yzb.pop();46}

47else

if(will==2)//

2下48

63else

6469}70

xzb.pop();

71yzb.pop();72}

73else

if(will==3)//

3左74

89else

9095}96

xzb.pop();

97yzb.pop();98}

99else

if(will==4)//

4右 100

115else

116121

}122

xzb.pop();

123yzb.pop();

124}

125}

126}

127int

main()

128

149}

150}

151152 scanf("

%d",&p);

153for(int i=1;i<=p;i++)

154165

xzb.push(bgx);

166yzb.push(bgy);

167bfs(bgx,bgy);

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

169179 printf("\n"

);180

}181

return0;

182 }

CodeVs 1026 逃跑的拉爾夫

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

Codevs 1026 逃跑的拉爾夫

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

codevs 1026 逃跑的拉爾夫

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