結果

問題 No.1400 すごろくで世界旅行
ユーザー kotatsugamekotatsugame
提出日時 2021-02-25 00:40:20
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
WA  
実行時間 -
コード長 905 bytes
コンパイル時間 945 ms
コンパイル使用メモリ 74,064 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-09-25 01:28:34
合計ジャッジ時間 10,317 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 AC 2 ms
6,940 KB
testcase_02 WA -
testcase_03 WA -
testcase_04 AC 2 ms
6,940 KB
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 AC 1,737 ms
6,940 KB
testcase_14 WA -
testcase_15 AC 2,016 ms
6,940 KB
testcase_16 AC 207 ms
6,940 KB
testcase_17 AC 189 ms
6,944 KB
testcase_18 AC 1,908 ms
6,940 KB
testcase_19 AC 2 ms
6,940 KB
testcase_20 AC 2 ms
6,940 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp:9:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
    9 | main()
      | ^~~~

ソースコード

diff #

#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];
main()
{
	cin>>V>>D;
	//V=2000;D=(1LL<<59)-1;
	for(int i=0;i<V;i++)
	{
		string s;cin>>s;
		//string s(V,'1');
		for(int j=i;j<V;j++)E[i][j]=s[j]-'0';
		A[i][i]=1;
	}
	if(D>V)D=V;
	while(D)
	{
		for(int i=0;i<V;i++)for(int j=i;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++)
			{
				bitset<2000>now=A[i];
				for(int j=i;j<V;j++)
				{
					A[i][j]=(now&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++)
			{
				bitset<2000>now=E[i];
				for(int j=i;j<V;j++)
				{
					E[i][j]=(now&ET[j]).any()?1:0;
				}
			}
		}
	}
	for(int i=0;i<V;i++)if(A[i].none())
	{
		cout<<"No"<<endl;
		return 0;
	}
	cout<<"Yes"<<endl;
}
0