結果
| 問題 | No.1400 すごろくで世界旅行 |
| コンテスト | |
| ユーザー |
yosswi414
|
| 提出日時 | 2019-12-30 01:13:59 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,628 bytes |
| 記録 | |
| コンパイル時間 | 1,669 ms |
| コンパイル使用メモリ | 182,820 KB |
| 実行使用メモリ | 48,000 KB |
| 最終ジャッジ日時 | 2024-11-28 15:46:03 |
| 合計ジャッジ時間 | 4,644 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 WA * 1 |
| other | AC * 10 WA * 6 RE * 2 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
using pi = pair<int, int>;
const int inf = 1e6;
signed main() {
int v, d;
cin >> v >> d;
vector<vector<bool>> G(v, vector<bool>(v, false));
for (int i = 0; i < v; ++i) {
string s;
cin >> s;
for (int j = 0; j < v; ++j) if (s[j] == '1') G[i][j] = true;
}
vector<vector<pi>> D(v, vector<pi>(v, pi(inf,inf)));
bool valid = true;
for (int src = 0; valid && src < v; ++src) {
queue<pi> que;
que.push(pi(src, 0));
bitset<1000> evis, ovis;
while (!que.empty()) {
pi q(que.front());
que.pop();
if(q.second%2){
if (ovis[q.first]) continue;
ovis.set(q.first);
D[q.first][src].first = min(D[q.first][src].first, q.second);
}
else if(q.second>0){
if (evis[q.first]) continue;
evis.set(q.first);
D[q.first][src].second = min(D[q.first][src].second, q.second);
}
D[src][q.first] = D[q.first][src];
for (int i = 0; i < v; ++i) if (!(q.second%2?evis:ovis)[i] && G[q.first][i]) que.push(pi(i, q.second + 1));
}
if ((d % 2 && ovis.count() < v) || (d % 2 == 0 && evis.count() < v)) valid = false;
if(d%2){
for (int i = 0; valid && i < v; ++i)
if (D[src][i].first > d) valid = false;
}
else{
for (int i = 0; valid && i < v; ++i)
if (D[src][i].second > d) valid = false;
}
}
cout << (valid ? "Yes" : ":(");
}
yosswi414