99962024-03-23 18:43:09111Két csoportcpp17Futási hiba 41/100197ms60300 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]?a[j]:v[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ÖsszpontTesztVerdiktIdőMemória
base41/100
1Elfogadva0/03ms1828 KiB
2Elfogadva0/059ms18448 KiB
3Elfogadva3/33ms2376 KiB
4Elfogadva3/33ms2256 KiB
5Elfogadva3/33ms2252 KiB
6Elfogadva3/33ms2416 KiB
7Elfogadva3/33ms2632 KiB
8Elfogadva2/23ms2856 KiB
9Elfogadva3/33ms3024 KiB
10Futási hiba0/33ms3160 KiB
11Futási hiba0/33ms3304 KiB
12Elfogadva3/38ms4944 KiB
13Futási hiba0/38ms4888 KiB
14Futási hiba0/38ms5240 KiB
15Elfogadva6/661ms19592 KiB
16Futási hiba0/759ms18952 KiB
17Futási hiba0/764ms22248 KiB
18Elfogadva6/6123ms36056 KiB
19Futási hiba0/6118ms34796 KiB
20Futási hiba0/6131ms41300 KiB
21Elfogadva6/6186ms53992 KiB
22Futási hiba0/7173ms50160 KiB
23Futási hiba0/7197ms57592 KiB
24Futási hiba0/7193ms60300 KiB