結果
問題 | No.1400 すごろくで世界旅行 |
ユーザー |
|
提出日時 | 2021-02-25 00:48:17 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 1,165 ms / 3,153 ms |
コード長 | 889 bytes |
コンパイル時間 | 872 ms |
コンパイル使用メモリ | 75,088 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-25 01:36:14 |
合計ジャッジ時間 | 6,449 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 18 |
コンパイルメッセージ
main.cpp:9:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type] 9 | main() | ^~~~
ソースコード
#pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2") #include<iostream> #include<bitset> using namespace std; int V; long D; bitset<2000>E[2000],ET[2000],A[2000],T[2000]; main() { cin>>V>>D; //V=2000;D=1e18; for(int i=0;i<V;i++) { string s;cin>>s; //string s(V,'1'); for(int j=0;j<V;j++)E[i][j]=s[j]-'0'; A[i][i]=1; } if(D>V*2)D=V*2; while(D) { for(int i=0;i<V;i++)for(int j=0;j<V;j++)ET[j][i]=E[i][j]; if(D&1) { for(int i=0;i<V;i++)T[i]=A[i]; for(int i=0;i<V;i++) { for(int j=i;j<V;j++) { A[i][j]=A[j][i]=(T[i]&ET[j]).any()?1:0; } } } D>>=1; if(D) { for(int i=0;i<V;i++)T[i]=E[i]; for(int i=0;i<V;i++) { for(int j=i;j<V;j++) { E[i][j]=E[j][i]=(T[i]&ET[j]).any()?1:0; } } } } for(int i=0;i<V;i++)for(int j=0;j<V;j++)if(!A[i][j]) { cout<<"No"<<endl; return 0; } cout<<"Yes"<<endl; }