結果
問題 | No.424 立体迷路 |
ユーザー |
|
提出日時 | 2019-08-26 23:47:33 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 941 bytes |
コンパイル時間 | 1,949 ms |
コンパイル使用メモリ | 199,136 KB |
最終ジャッジ日時 | 2025-01-07 15:22:06 |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 21 |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef long long ll; int dy[]={0,1,0,-1}; int dx[]={1,0,-1,0}; int h,w; void dfs(int y,int x,string s[],vector<vector<int>>& v) { if (v[y][x]) return; v[y][x]=1; for (int i=0;i<4;i++) { int ny=y+dy[i]; int nx=x+dx[i]; if (ny<0||h<=ny||nx<0||w<=nx) continue; if (abs(s[y][x]-s[ny][nx])<=1) dfs(ny,nx,s,v); int ny2=ny+dy[i]; int nx2=nx+dx[i]; if (ny2<0||h<=ny2||nx2<0||w<=nx2) continue; if (s[y][x]==s[ny2][nx2]&&s[y][x]>s[ny][nx]) dfs(ny2,nx2,s,v); } } int main() { int sy,sx,gy,gx; cin>>h>>w>>sy>>sx>>gy>>gx; sy--,sx--,gy--,gx--; string s[h]; for (int i=0;i<h;i++) cin>>s[i]; vector<vector<int>> v(h,vector<int>(w,0)); dfs(sy,sx,s,v); if (v[gy][gx]) puts("YES"); else puts("NO"); return 0; }