時間限制: 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 #include3using
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 #include5using
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 年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能...