結果
| 問題 | 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;
}
            
            
            
        