結果
問題 |
No.2064 Smallest Sequence on Grid
|
ユーザー |
![]() |
提出日時 | 2024-09-12 13:46:11 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 1,405 ms / 3,000 ms |
コード長 | 804 bytes |
コンパイル時間 | 2,121 ms |
コンパイル使用メモリ | 204,380 KB |
最終ジャッジ日時 | 2025-02-24 06:44:18 |
ジャッジサーバーID (参考情報) |
judge4 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 29 |
ソースコード
#include<bits/stdc++.h> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int H,W; cin>>H>>W; vector<string>S(H); for(int i=0;i<H;i++)cin>>S[i]; set<pair<int,int>>cand; cand.insert(make_pair(0,0)); string T(1,S[0][0]); for(int t=0;t<H+W-2;t++) { char min_char='z'; for(auto[r,c]:cand) { if(r+1<H)min_char=min(min_char,S[r+1][c]); if(c+1<W)min_char=min(min_char,S[r][c+1]); } T.push_back(min_char); set<pair<int,int>>tmp; for(auto[r,c]:cand) { if(r+1<H&&S[r+1][c]==min_char)tmp.insert(make_pair(r+1,c)); if(c+1<W&&S[r][c+1]==min_char)tmp.insert(make_pair(r,c+1)); } cand=tmp; } cout<<T<<endl; }