9995 2024. 03. 23 18:42:16 111 Két csoport cpp17 Futási hiba 41/100 187ms 59540 KiB
#include<bits/stdc++.h>
using namespace std;
#define int long long
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
#ifndef ONLINE_JUDGE
	freopen("be2.txt","r",stdin);
#endif
	int N;
	cin>>N;
	vector<vector<int>>g(N+1);
	for(int i=1;i<=N;i++){
		for(int j;cin>>j,j;){
			g[i].push_back(j);
		}
	}
	vector<int>v(N+1);
	auto dfs1=[&](auto self,int i)->void{
		for(int j:g[i]){
			if(v[j]){
				continue;
			}
			v[j]=v[i]^3;
			self(self,j);
		}
	};
	vector<int>a(N+1);
	auto dfs2=[&](auto self,int i)->void{
		int c=0;
		for(int j:g[i]){
			if(a[j]==v[i]){
				c++;
			}
		}
		if(c>1){
			a[i]=v[i]^3;
		}
		else{
			a[i]=v[i];
		}
		for(int j:g[i]){
			if(a[j]){
				continue;
			}
			self(self,j);
		}
	};
	for(int i=1;i<=N;i++){
		if(v[i]){
			continue;
		}
		v[i]=1;
		a[i]=1;
		dfs1(dfs1,i);
		dfs2(dfs2,i);
	}
	for(int i=1;i<=N;i++){
		int c=0;
		for(int j:g[i]){
			if(a[j]==a[i]){
				c++;
			}
		}
		if(c>1){
			exit(1);
		}
	}
	vector<int>ans;
	for(int i=1;i<=N;i++){
		if(a[i]==1){
			ans.push_back(i);
		}
	}
	cout<<ans.size()<<'\n';
	for(int i:ans){
		cout<<i<<' ';
	}
	cout<<'\n';
	return 0;
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 41/100
1 Elfogadva 0/0 3ms 1828 KiB
2 Elfogadva 0/0 59ms 18444 KiB
3 Elfogadva 3/3 3ms 2356 KiB
4 Elfogadva 3/3 3ms 2436 KiB
5 Elfogadva 3/3 3ms 2512 KiB
6 Elfogadva 3/3 3ms 2636 KiB
7 Elfogadva 3/3 3ms 2716 KiB
8 Elfogadva 2/2 3ms 2716 KiB
9 Elfogadva 3/3 3ms 2808 KiB
10 Futási hiba 0/3 3ms 2952 KiB
11 Futási hiba 0/3 3ms 2908 KiB
12 Elfogadva 3/3 8ms 4544 KiB
13 Futási hiba 0/3 8ms 4660 KiB
14 Futási hiba 0/3 8ms 4888 KiB
15 Elfogadva 6/6 59ms 19332 KiB
16 Futási hiba 0/7 56ms 18432 KiB
17 Futási hiba 0/7 61ms 21540 KiB
18 Elfogadva 6/6 118ms 35532 KiB
19 Futási hiba 0/6 112ms 34260 KiB
20 Futási hiba 0/6 125ms 40716 KiB
21 Elfogadva 6/6 177ms 53292 KiB
22 Futási hiba 0/7 167ms 49524 KiB
23 Futási hiba 0/7 187ms 56776 KiB
24 Futási hiba 0/7 187ms 59540 KiB