結果
| 問題 | No.1805 Approaching Many Typhoon |
| ユーザー |
pengin_2000
|
| 提出日時 | 2022-08-21 13:42:07 |
| 言語 | C (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 790 bytes |
| 記録 | |
| コンパイル時間 | 311 ms |
| コンパイル使用メモリ | 30,592 KB |
| 実行使用メモリ | 6,820 KB |
| 最終ジャッジ日時 | 2024-10-10 06:07:22 |
| 合計ジャッジ時間 | 1,637 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 35 |
ソースコード
#include<stdio.h>
int f[2003], t[2003];
int I[502];
int v[2003];
int p[2003];
int root(int n)
{
if (p[n] != n)
p[n] = root(p[n]);
return p[n];
}
void uni(int a, int b)
{
a = root(a);
b = root(b);
p[a] = b;
return;
}
int main()
{
int n, m;
scanf("%d %d", &n, &m);
int s, g;
scanf("%d %d", &s, &g);
s--;
g--;
int i;
for (i = 0; i < m; i++)
{
scanf("%d %d", &f[i], &t[i]);
f[i]--;
t[i]--;
}
int u;
scanf("%d", &u);
for (i = 0; i < u; i++)
{
scanf("%d", &I[i]);
I[i]--;
}
for (i = 0; i < n; i++)
v[i] = 0;
for (i = 0; i < u; i++)
v[I[i]]++;
for (i = 0; i < n; i++)
p[i] = i;
for (i = 0; i < m; i++)
{
if (v[f[i]] > 0 || v[t[i]] > 0)
continue;
uni(f[i], t[i]);
}
if (root(s) == root(g))
printf("Yes\n");
else
printf("No\n");
return 0;
}
pengin_2000