結果

問題 No.583 鉄道同好会
ユーザー srup٩(๑`н´๑)۶srup٩(๑`н´๑)۶
提出日時 2017-10-27 23:23:44
言語 C++11
(gcc 11.4.0)
結果
RE  
実行時間 -
コード長 2,252 bytes
コンパイル時間 2,161 ms
コンパイル使用メモリ 169,760 KB
実行使用メモリ 25,880 KB
最終ジャッジ日時 2024-11-21 23:17:41
合計ジャッジ時間 28,095 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 AC 2 ms
11,904 KB
testcase_03 AC 2 ms
10,624 KB
testcase_04 RE -
testcase_05 RE -
testcase_06 WA -
testcase_07 AC 2 ms
13,312 KB
testcase_08 AC 2 ms
10,624 KB
testcase_09 RE -
testcase_10 RE -
testcase_11 TLE -
testcase_12 TLE -
testcase_13 TLE -
testcase_14 TLE -
testcase_15 TLE -
testcase_16 TLE -
testcase_17 TLE -
testcase_18 TLE -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef vector<int> vint;
typedef pair<int,int> pint;
typedef vector<pint> vpint;
#define rep(i,n) for(int i=0;i<(n);i++)
#define REP(i,n) for(int i=n-1;i>=(0);i--)
#define reps(i,f,n) for(int i=(f);i<(n);i++)
#define each(it,v) for(__typeof((v).begin()) it=(v).begin();it!=(v).end();it++)
#define all(v) (v).begin(),(v).end()
#define eall(v) unique(all(v), v.end())
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define chmax(a, b) a = (((a)<(b)) ? (b) : (a))
#define chmin(a, b) a = (((a)>(b)) ? (b) : (a))
const int MOD = 1e9 + 7;
const int INF = 1e9;
const ll INFF = 1e18;

int Sa[300000], Sb[300000];
int memo[1010];

class DisjointSet{
public:
	vector<int> rank, p;//rank:木の高さ p:親の頂点番号
	DisjointSet(){}
	DisjointSet(int size){//頂点の数
		rank.resize(size, 0);
		p.resize(size, 0);
		rep(i, size) makeSet(i);
	}
	bool same(int x, int y){ //同じ木にあるか
		return findSet(x) == findSet(y);
	}
	void unite(int x, int y){ // 木どうしをくっつける
		link(findSet(x), findSet(y));
	}
private:
	void makeSet(int x){
		p[x] = x;
		rank[x] = 0;
	}
	int findSet(int x){ //親を探す(ルートまで)
		if(x != p[x]){
			p[x] = findSet(p[x]);
		}
		return p[x];
	}
	void link(int x, int y){ //木の高さを考慮して木どうしをくっつける
		if(rank[x] > rank[y]){
			p[y] = x;
		}else{
			p[x] = y;
			if(rank[x] == rank[y]) rank[y]++;
		}
	}
};

set<int> se[1010];

int main(void) {
	int N, M; cin >> N >> M;
	rep(i, M) cin >> Sa[i] >> Sb[i];

	rep(i, M) se[Sa[i]].insert(2 * i), se[Sb[i]].insert(2 * i + 1);
	// 連結か見る
	DisjointSet uf(2 * M);
	rep(i, N) uf.unite(2 * i, 2 * i + 1);
	rep(i, N) {
		// printf("i %d\n", i);
		for(auto u : se[i]) for(auto v : se[i]) {
			// printf("u %d v %d\n", u, v);
			uf.unite(u, v);
		}
	}

	bool f = true;
	rep(i, 2 * M)rep(j, 2 * M) {
		auto d = uf.same(i, j);
		// printf("%d %d %d\n", i, j, d);
		if(!d) f = false;
	}
	if(f == false) {
		printf("NO\n");
		return 0;
	}

	rep(i, M) memo[Sa[i]]++, memo[Sb[i]]++;
	int cnt = 0;
	rep(i, N) if(memo[i] % 2) cnt++;
	if(cnt == 2) printf("YES\n");
	else printf("NO\n");
	
	// printf("YES\n");
	return 0;
}
0