Submission #994165


Source Code Expand

#include "bits/stdc++.h"
using namespace std;

//諸機能
#pragma region MACRO 
#define putans(x)  std::cerr << "[ answer ]: " ; cout << (x) << endl
#define dputans(x) std::cerr << "[ answer ]: "; cout << setprecision(40) << (double)(x) << endl
#define REP(i,a,n) for(int i=(a); i<(int)(n); i++)
#define RREP(i,n,a) for(int i=(int)(n-1); i>= a; i--)
#define rep(i,n) REP(i,0,n)
#define rrep(i,n) RREP(i,n,0)
#define all(a) begin((a)),end((a))
#define mp make_pair
#define exist(container, n) ((container).find((n)) != (container).end())
#define equals(a,b) (fabs((a)-(b)) < EPS)
#ifdef _DEBUG //ファイルからテストデータを読み込む
std::ifstream ifs("data.txt");
#define put ifs >>
#else //ジャッジシステムでいい感じにやる
#define put cin >>
#endif
#pragma endregion
//デバッグなどの支援
#pragma region CODING_SUPPORT
#ifdef _DEBUG
#define dbg(var0) { std::cerr << ( #var0 ) << "=" << ( var0 ) << endl; }
#define dbg2(var0, var1) { std::cerr << ( #var0 ) << "=" << ( var0 ) << ", "; dbg(var1); }
#define dbg3(var0, var1, var2) { std::cerr << ( #var0 ) << "=" << ( var0 ) << ", "; dbg2(var1, var2); }
#define dbgArray(a,n) {std::cerr << (#a) << "=";  rep(i,n){std::cerr <<(a[i])<<",";} cerr<<endl;} 
#else
#define dbg(var0) {}
#define dbg2(var0, var1) {}
#define dbg3(var0, var1, var2) {}
#define dbgArray(a,n) {}
#endif 
#pragma endregion 
//typedef(書き換える、書き足す可能性ある)
#pragma region TYPE_DEF
typedef long long ll;
typedef pair<int, int> pii; typedef pair<string, string> pss; typedef pair<int, string>pis;
typedef pair<long long, long long> pll;
typedef vector<int> vi;
#pragma endregion
//諸々の定数(書き換える可能性ある)
#pragma region CONST_VAL
#define PI (2*acos(0.0))
#define EPS (1e-10)
#define MOD (ll)(1e9 + 7)
#define INF (1000000)
#pragma endregion



//warshallFloyd
int V = 1000;
static const int MAX_V = 1000;
int d[MAX_V][MAX_V];

void warshallFloyd() {
	rep(k, V) {
		rep(i, V) {
			rep(j, V) {
				if (d[i][k] == INF || d[k][j] == INF) continue;
				d[i][j] = min(d[i][j], d[i][k] + d[k][j]);
			}
		}
	}
}

int main() {
	int n, m; put n >> m;
	fill(*d, *d + 1000 * 1000, INF);
	rep(i, n) {
		d[i][i] = 0;
	}
	set<int> l[500000];
	set<int> usedL[500000];
	rep(i, n) {
		int k; put k;
		rep(j, k) {
			int s; put s;
			l[s - 1].insert(i);
			usedL[i].insert(s - 1);
		}
	}
	rep(i, n) {
		REP(j, i + 1, n) {
			for (auto k = usedL[i].begin(); k != usedL[i].end(); k++)
			{
				if (usedL[j].find(*k) != usedL[j].end()) {
					d[i][j] = 1;
					d[j][i] = 1;
					break;
				}
			}

		}
	}
	warshallFloyd();
	rep(i, n) {
		rep(j, n) {
			if (d[i][j] == INF) {
				cout << "NO";
				return 0;
			}
		}
	}
	cout << "YES" << endl;
	return 0;
	set<int> connected = { 0 };
	set<int> enableLang = usedL[0];
	REP(i, 1, n) {//i番目の人
				  //if (l[i].size() < 2)continue;

		for (auto k = usedL[i].begin(); k != usedL[i].end(); k++)
		{
			if (enableLang.find(*k) != enableLang.end())
			{
				connected.insert(*k);
				for (auto ls = usedL[i].begin(); ls != usedL[i].end(); ls++)
				{
					enableLang.insert(*ls);
				}
				break;
			}
		}
	}
	cout << ( connected.size() == n ? "YES" : "NO" ) << endl;

END:
	return 0;
}
//
//int n, a; put n >> a;
//if (n > 1000001) {
//	return 0;
//}
//ll dp[1000001];
//rep(i, 1000001) {
//	dp[i] = i;
//}
//
//REP(i, 1, n + 1) {
//	int base = dp[i];
//	int j = 1;
//	int useTime = a + j;
//	while (i*j < n + 1) {
//		dp[i*j] = min(dp[i*j], dp[i] + useTime);
//		j++;
//		useTime++;
//	}
//	int s = 0;
//}
//ll minT = n;
//REP(i, 1, n) {
//	minT = min(minT, dp[i] + a + 1 + n / i);
//}

Submission Info

Submission Time
Task C - Interpretation
User pekoong
Language C++14 (GCC 5.4.1)
Score 200
Code Size 3782 Byte
Status RE
Exec Time 1383 ms
Memory 51072 KB

Judge Result

Set Name sample dataset1 dataset2
Score / Max Score 0 / 0 200 / 200 0 / 200
Status
AC × 2
AC × 12
AC × 12
RE × 13
Set Name Test Cases
sample sample-01.txt, sample-02.txt
dataset1 sample-01.txt, sample-02.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt
dataset2 sample-01.txt, sample-02.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 02-01.txt, 02-02.txt, 02-03.txt, 02-04.txt, 02-05.txt, 02-06.txt, 02-07.txt, 02-08.txt, 02-09.txt, 02-10.txt, 02-11.txt, 02-12.txt, 02-13.txt
Case Name Status Exec Time Memory
01-01.txt AC 724 ms 51072 KB
01-02.txt AC 727 ms 51072 KB
01-03.txt AC 730 ms 51072 KB
01-04.txt AC 1332 ms 51072 KB
01-05.txt AC 832 ms 51072 KB
01-06.txt AC 741 ms 51072 KB
01-07.txt AC 793 ms 51072 KB
01-08.txt AC 745 ms 51072 KB
01-09.txt AC 747 ms 51072 KB
01-10.txt AC 1383 ms 51072 KB
02-01.txt RE 115 ms 4096 KB
02-02.txt RE 115 ms 4096 KB
02-03.txt RE 118 ms 4096 KB
02-04.txt RE 116 ms 4096 KB
02-05.txt RE 116 ms 4096 KB
02-06.txt RE 116 ms 4096 KB
02-07.txt RE 116 ms 4096 KB
02-08.txt RE 118 ms 4096 KB
02-09.txt RE 115 ms 4096 KB
02-10.txt RE 116 ms 4096 KB
02-11.txt RE 116 ms 4096 KB
02-12.txt RE 114 ms 4096 KB
02-13.txt RE 114 ms 4096 KB
sample-01.txt AC 725 ms 51072 KB
sample-02.txt AC 724 ms 51072 KB