Submission #38791137


Source Code Expand

//#include "bits/stdc++.h"

#define _USE_MATH_DEFINES

#include <iostream>
#include <sstream>
#include <iomanip>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <numeric>
#include <functional>
#include <utility>
#include <tuple>
#include <vector>
#include <string>
#include <list>
#include <set>
#include <unordered_set>
#include <map>
#include <unordered_map>
#include <queue>
#include <deque>
#include <stack>
#include <iterator>
#include <bitset>
#include <complex>
#include <limits>
#include <random>
#include<fstream>
#include<array>
#include<assert.h>


using namespace std;

#define rep(i,a,b) for(int i=(a), i##_len=(b);i<i##_len;i++)
#define rrep(i,a,b) for(int i=(b)-1;i>=(a);i--)
#define all(c) begin(c),end(c)

#define int ll
#define SZ(x) ((int)(x).size())
#define pb push_back
#define mp make_pair

typedef unsigned long long ull;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
typedef pair<ll, int> pli;
typedef pair<double, double> pdd;
typedef vector< vector<int> > mat;

template<class T> bool chmax(T &a, const T &b) { if (a < b) { a = b; return true; } return false; }
template<class T> bool chmin(T &a, const T &b) { if (b < a) { a = b; return true; } return false; }

const int INF = sizeof(int) == sizeof(long long) ? 0x3f3f3f3f3f3f3f3fLL : 0x3f3f3f3f;
//const int MOD =  (int)1e9 + 7;
const int MOD = 998244353;

const double EPS = 1e-9;

signed main()
{
	cin.tie(0);
	ios::sync_with_stdio(false);

	int N, M;
	cin >> N >> M;

	vector<vector<int>> A(M);
	rep(i, 0, M)
	{
		int c;
		cin >> c;
		rep(j, 0, c)
		{
			int v;
			cin >> v;
			v--;
			A[i].push_back(v);
		}
	}

	int ans = 0;
	rep(i, 0, 1 << M)
	{
		vector<bool> F(N, false);
		rep(j, 0, M)
		{
			if (i >> j & 1)
			{
				for (auto v : A[j])F[v] = true;
			}
		}
		bool ok = true;
		for (auto f : F)if (!f)ok = false;
		if (ok)ans++;
	}

	cout << ans << endl;
	
	return 0;
}

Submission Info

Submission Time
Task C - Coverage
User aquel
Language C++ (GCC 9.2.1)
Score 300
Code Size 2048 Byte
Status AC
Exec Time 7 ms
Memory 3556 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 300 / 300
Status
AC × 3
AC × 26
Set Name Test Cases
Sample 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt
All 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_random_00.txt, 01_random_01.txt, 01_random_02.txt, 01_random_03.txt, 01_random_04.txt, 01_random_05.txt, 01_random_06.txt, 01_random_07.txt, 01_random_08.txt, 01_random_09.txt, 02_sparse_00.txt, 02_sparse_01.txt, 02_sparse_02.txt, 02_sparse_03.txt, 02_sparse_04.txt, 02_sparse_05.txt, 02_sparse_06.txt, 02_sparse_07.txt, 02_sparse_08.txt, 02_sparse_09.txt, 03_corner_00.txt, 03_corner_01.txt, 03_corner_02.txt
Case Name Status Exec Time Memory
00_sample_00.txt AC 7 ms 3400 KiB
00_sample_01.txt AC 2 ms 3536 KiB
00_sample_02.txt AC 2 ms 3520 KiB
01_random_00.txt AC 2 ms 3504 KiB
01_random_01.txt AC 2 ms 3540 KiB
01_random_02.txt AC 2 ms 3500 KiB
01_random_03.txt AC 2 ms 3432 KiB
01_random_04.txt AC 2 ms 3508 KiB
01_random_05.txt AC 2 ms 3460 KiB
01_random_06.txt AC 2 ms 3480 KiB
01_random_07.txt AC 2 ms 3556 KiB
01_random_08.txt AC 2 ms 3432 KiB
01_random_09.txt AC 2 ms 3408 KiB
02_sparse_00.txt AC 2 ms 3512 KiB
02_sparse_01.txt AC 2 ms 3456 KiB
02_sparse_02.txt AC 2 ms 3512 KiB
02_sparse_03.txt AC 2 ms 3404 KiB
02_sparse_04.txt AC 2 ms 3456 KiB
02_sparse_05.txt AC 3 ms 3484 KiB
02_sparse_06.txt AC 2 ms 3540 KiB
02_sparse_07.txt AC 2 ms 3520 KiB
02_sparse_08.txt AC 2 ms 3460 KiB
02_sparse_09.txt AC 2 ms 3556 KiB
03_corner_00.txt AC 2 ms 3540 KiB
03_corner_01.txt AC 2 ms 3552 KiB
03_corner_02.txt AC 2 ms 3392 KiB