結果
| 問題 |
No.583 鉄道同好会
|
| コンテスト | |
| ユーザー |
sca1l
|
| 提出日時 | 2017-10-28 00:24:00 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 1,447 ms / 2,000 ms |
| コード長 | 1,570 bytes |
| コンパイル時間 | 3,125 ms |
| コンパイル使用メモリ | 84,684 KB |
| 実行使用メモリ | 65,792 KB |
| 最終ジャッジ日時 | 2024-11-22 00:05:18 |
| 合計ジャッジ時間 | 12,712 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 16 |
ソースコード
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int m = sc.nextInt();
int[] c = new int[n];
ArrayList[] x = new ArrayList[n];
for(int i=0; i<n; i++){
x[i] = new ArrayList<Integer>();
}
int at = 0;
for(int i=0; i<m; i++){
int a = sc.nextInt();
int b = sc.nextInt();
x[a].add(b);
x[b].add(a);
c[a]++;
c[b]++;
at = a;
}
int con = 0;
ArrayList<Integer> q = new ArrayList<Integer>();
q.add(at);
boolean[] ch = new boolean[n];
while(q.size()>0){
int now = q.remove(q.size()-1);
ch[now] = true;
for(int i=0; i<x[now].size(); i++){
int ne = (int)x[now].get(i);
if(ch[ne]){
continue;
}
q.add(ne);
}
con++;
}
int uni = 0;
int odd = 0;
for(int i=0; i<n; i++){
if(c[i]%2==1){
odd++;
}
if(c[i]>0){
uni++;
}
}
if(con<uni){
System.out.println("NO");
System.exit(0);
}
if(odd==0 || odd==2){
System.out.println("YES");
}else{
System.out.println("NO");
}
}
}
sca1l