結果
| 問題 |
No.3199 Key-Door Grid
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-07-11 21:40:58 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,619 bytes |
| コンパイル時間 | 2,189 ms |
| コンパイル使用メモリ | 214,572 KB |
| 実行使用メモリ | 21,632 KB |
| 最終ジャッジ日時 | 2025-07-11 21:41:13 |
| 合計ジャッジ時間 | 5,418 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 26 WA * 11 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:44:25: warning: ‘gx’ may be used uninitialized [-Wmaybe-uninitialized]
44 | for(auto d : dist.at(gx).at(gy)) if(d != -1) answer = min(answer,d);
| ~~~~~~~^~~~
main.cpp:13:15: note: ‘gx’ was declared here
13 | int sx,sy,gx,gy;
| ^~
main.cpp:44:32: warning: ‘gy’ may be used uninitialized [-Wmaybe-uninitialized]
44 | for(auto d : dist.at(gx).at(gy)) if(d != -1) answer = min(answer,d);
| ~~~~~~~~~~~~~~^~~~
main.cpp:13:18: note: ‘gy’ was declared here
13 | int sx,sy,gx,gy;
| ^~
In file included from /usr/include/c++/13/bits/memory_resource.h:47,
from /usr/include/c++/13/string:58,
from /usr/include/c++/13/bitset:52,
from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:52,
from main.cpp:1:
In constructor ‘constexpr std::_Head_base<_Idx, _Head, false>::_Head_base(_UHead&&) [with _UHead = int&; long unsigned int _Idx = 0; _Head = int]’,
inlined from ‘constexpr std::_Tuple_impl<_Idx, _Head, _Tail ...>::_Tuple_impl(_UHead&&, _UTail&& ...) [with _UHead = int&; _UTail = {int&, int}; <template-parameter-2-3> = void; long unsigned int _Idx = 0; _Head = int; _Tail = {int, int}]’ at /usr/include/c++/13/tuple:293:38,
inlined from ‘constexpr std::tuple< <template-parameter-1-1> >::tuple(_UElements&& ...) [with _UElements = {int&, int&, int}; bool _Valid = true; typename std::enable_if<_TCC<_Valid>::__is_implicitly_constructible<_UElements ...>(), bool>::type <anonymous> = true; _Elements = {int, int, int}]’ at /usr/include/c++/13/tuple:891:54,
inlined from ‘int main()’ at main.cpp:18:40:
/usr/include/c++/13/tuple:201:11: warning: ‘sx’ may be used uninitialized [-Wmaybe-uninitialized]
201 | : _M_head_impl(std::forward<_UHead>(__h)) { }
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
ma
ソースコード
#include <bits/stdc++.h>
using namespace std;
int main(){
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
int H,W,M; cin >> H >> W >> M;
vector<string> S(H);
for(auto &s : S) cin >> s;
vector<vector<vector<int>>> dist(H,vector<vector<int>>(W,vector<int>(M+1,-1)));
int sx,sy,gx,gy;
for(int i=0; i<H; i++) for(int k=0; k<W; k++){
if(S.at(i).at(k) == 'S') sx = i,sy = k;
if(S.at(i).at(k) == 'G') gx = i,gy = k;
}
queue<tuple<int,int,int>> Q; Q.push({sx,sy,0});
dist.at(sx).at(sy).at(0) = 0;
vector<pair<int,int>> dxy = {{-1,0},{0,1},{1,0},{0,-1}};
while(Q.size()){
auto [x,y,m] = Q.front(); Q.pop();
int d = dist.at(x).at(y).at(m);
if('1' <= S.at(x).at(y) && S.at(x).at(y) <= '9'){
int v = S.at(x).at(y)-'0';
if(v != m){
if(dist.at(x).at(y).at(v) != -1) continue;
dist.at(x).at(y).at(v) = d,Q.push({x,y,v}); continue;
}
}
for(auto [dx,dy] : dxy){
int nx = x+dx,ny = y+dy;
if(nx < 0 || ny < 0 || nx >= H || ny >= W) continue;
if(S.at(nx).at(ny) == '#') continue;
if(dist.at(nx).at(ny).at(m) != -1) continue;
if('a' <= S.at(nx).at(ny) && S.at(nx).at(ny) <= 'i'){
if(S.at(nx).at(ny)-'a'+1 != m) continue;
}
dist.at(nx).at(ny).at(m) = d+1,Q.push({nx,ny,m});
}
}
int answer = 1000000;
for(auto d : dist.at(gx).at(gy)) if(d != -1) answer = min(answer,d);
if(answer == 1000000) answer = -1;
cout << answer << endl;
}