127592024-12-30 00:17:14xxxKerékpártúra (50 pont)cpp17Accepted 50/50137ms6200 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long

#define f first
#define s second
const int mxN = 13000;
vector<vector<int> > adj(mxN), adj2(mxN);
set<int> ans;
bool vis[mxN], vis2[mxN];

void dfs(int v) {
	vis[v] = 1;
	for(auto u : adj2[v]) {
		if (!vis[u]) {
			dfs(u);
		}
	}
}

void dfs2(int v) {
	vis2[v] = 1;
	if (vis[v] == 1) {
		ans.insert(v);
	} else {
		ans.insert(v);
		return;
	}

	for(auto u : adj[v]) {
		if (!vis2[u]) {
			dfs2(u);
		}
	}
}



signed main() {
	int n, m, k;
	cin >> n >> m >> k;

	for(int i = 0; i < m; i++) {
		int x, y;
		cin >> x >> y;
		adj[x].push_back(y);
		adj2[y].push_back(x);
	}

	dfs(k);
	dfs2(k);

	cout << ans.size()-1 << endl;
	for(auto x : ans) {
		if (x!=k)
		cout << x << ' ';
	}


}
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/02ms824 KiB
2Accepted0/020ms1712 KiB
3Accepted2/21ms824 KiB
4Accepted2/22ms824 KiB
5Accepted2/21ms824 KiB
6Accepted2/22ms824 KiB
7Accepted2/21ms824 KiB
8Accepted2/23ms1060 KiB
9Accepted2/24ms1084 KiB
10Accepted2/24ms1080 KiB
11Accepted2/24ms1160 KiB
12Accepted2/213ms1408 KiB
13Accepted2/212ms1540 KiB
14Accepted2/221ms2060 KiB
15Accepted3/335ms2492 KiB
16Accepted4/441ms2868 KiB
17Accepted4/457ms3416 KiB
18Accepted3/352ms3388 KiB
19Accepted3/345ms3196 KiB
20Accepted3/3119ms5552 KiB
21Accepted3/3135ms5944 KiB
22Accepted3/3137ms6200 KiB