結果
| 問題 |
No.1638 Robot Maze
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-08-06 21:57:12 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,506 bytes |
| コンパイル時間 | 1,771 ms |
| コンパイル使用メモリ | 172,172 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-17 01:55:20 |
| 合計ジャッジ時間 | 3,226 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 43 WA * 6 |
ソースコード
#include <bits/stdc++.h>
using namespace std ;
typedef long long ll ;
typedef pair<int,int> P ;
#define rep(i,n) for(int i = 0 ; i < n ; i++)
#define rrep(i,a,b) for(int i = a ; i < b ; i++)
const int dx[4] = {-1,0,1,0} , dy[4] = {0,1,0,-1} ;
ll cost[4] ;
int H , W ;
ll u , d , r , l , k , p ;
int xs , ys , xg , yg ;
char S[110][110] ;
ll dist[110][110] ;
void bfs(){
rep(i,H) rep(j,W) dist[i][j] = 1e17 ;
dist[xs][ys] = 0 ;
queue<P> que ;
que.push(P(xs,ys)) ;
while(!que.empty()){
P pr = que.front() ; que.pop() ;
int x = pr.first , y = pr.second ;
for(int i = 0 ; i < 4 ; i++){
int nx = x + dx[i] , ny = y + dy[i] ;
if(0 > nx || nx >= H || 0 > ny || ny >= W || S[nx][ny] == '#') continue ;
if(S[nx][ny] == '@' && dist[nx][ny] > dist[x][y] + p + cost[i]){
dist[nx][ny] = dist[x][y] + p + cost[i] ;
que.push(P(nx,ny)) ;
continue ;
}
if(dist[nx][ny] > dist[x][y] + cost[i]){
dist[nx][ny] = dist[x][y] + cost[i] ;
que.push(P(nx,ny)) ;
continue ;
}
}
}
}
int main(){
cin >> H >> W >> u >> d >> r >> l >> k >> p >> xs >> ys >> xg >> yg ;
cost[0] = u ;
cost[1] = r ;
cost[2] = d ;
cost[3] = l ;
xs-- ; ys-- ; xg-- ; yg-- ;
rep(i,H) rep(j,W) cin >> S[i][j] ;
bfs() ;
if(dist[xg][yg] > k) cout << "No" << endl ;
else cout << "Yes" << endl ;
}