題目描述 description題目芒果君:原來直接抄的題解…………今天重新打…………其實本題有點像dp,因為這一層的點tail必須由上一層的head擴充套件而來,但如果你把所有點都塞到佇列裡面而寫while(head!=tail),就會發生這一層辛辛苦苦擴充套件的點被再次取出卻只能扔掉的慘劇。於是層與層之間的關係必須分清楚。我們記錄新tail的個數為cnt,用來更新的head的個數為frontcnt,發現這一層的cnt是下一層的frontcnt,這樣我們每次用frontcnt來限制點的出隊次數就能解決了。年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。
那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。
編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。
小鎮的地圖是矩形的,上面的符號用來標明哪兒可以行車哪兒不行。「.」表示小鎮上那塊地方是可以行車的,而符號「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 input45
.....
.x...
...*x
x.x..
3north
west
south
樣例輸出 sample output
.....
*x*..
*.*.x
x.x..
1 #include2 #include3 #include4 #include5 #include6 #include7using
namespace
std;
8struct
node
11};
12 queueq;
13int vis[60][60],mp[60][60],n,m,q,dx[4]=,dy[4]=;//
n s w e
14char ch,s[9
];15 inline bool ok(int x,int y)
16int
main()
1727}28
int frontcnt=1,cnt=0
;29 scanf("
%d",&q);
30while(q--)
39 cnt=0;40
for(int i=1;i<=n;++i) for(int j=1;j<=m;++j) vis[i][j]=0
; 41
while(frontcnt--)53}
54 frontcnt=cnt;55}
56for(int i=1;i<=n;++i)
62 puts(""
);63}64
return0;
65 }
CodeVs 1026 逃跑的拉爾夫
題目描述 年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。小鎮的地圖是矩形...
Codevs 1026 逃跑的拉爾夫
時間限制 1 s 空間限制 128000 kb 題目等級 gold 題目描述 description 那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能的位置。小鎮的地圖是矩形的,上面的符號用來標明哪兒...
codevs 1026 逃跑的拉爾夫
題目描述 description 年輕的拉爾夫開玩笑地從乙個小鎮上偷走了一輛車,但他沒想到的是那輛車屬於警察局,並且車上裝有用於發射車子移動路線的裝置。那個裝置太舊了,以至於只能發射關於那輛車的移動路線的方向資訊。編寫程式,通過使用一張小鎮的地圖幫助警察局找到那輛車。程式必須能表示出該車最終所有可能...