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 |
|
|
|
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 |