結果
問題 |
No.1587 012 Matrix
|
ユーザー |
![]() |
提出日時 | 2024-08-08 15:25:54 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 13 ms / 1,000 ms |
コード長 | 774 bytes |
コンパイル時間 | 1,046 ms |
コンパイル使用メモリ | 99,532 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-08-08 15:25:56 |
合計ジャッジ時間 | 2,707 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 22 |
ソースコード
#include<iostream> #include<vector> #include<algorithm> using namespace std; using ll = long long; int main(){ cin.tie(nullptr); ios::sync_with_stdio(false); int n; cin>>n; vector<vector<int>> ans(n,vector<int>(n,0)); auto dfs = [&](auto dfs,int le,int ri) -> void { int len = ri - le; if(len==2){ ans[le][le] = 0; ans[le][le+1] = 1; ans[le+1][le] = ans[le+1][le+1] = 2; return; } dfs(dfs,le+1,ri-1); ans[le][ri-1] = 1; for(int i = le;i<ri;i++) ans[ri-1][i] = 2; for(int i = le+1;i<ri;i++) ans[i][ri-1] = 2; }; dfs(dfs,0,n); for(int i = 0;i<n;i++){ for(int j = 0;j<n;j++) cout<<ans[i][j]; cout<<endl; } }