91842024-02-17 16:50:24xxxA lehető legkevesebb metróval utazás (40 pont)cpp14Hibás válasz 0/40570ms9488 KiB
#include <bits/stdc++.h>
using namespace std;

int main() {
	ios::sync_with_stdio(NULL); cin.tie(NULL); cout.tie(NULL);
	int n, m, ind, erk;
	cin >> n >> m >> ind >> erk;
	vector<vector<int> > megall(m+1);
	vector<vector<bool> > el(n+1, vector<bool>(n+1, false));
	for(int i = 0; i < n; i++) {
		int db;
		cin >> db;
		for(int j = 0; j < db; j++) {
			int x;
			cin >> x;
			megall[x].push_back(i);
		}
	}

	

	for(int i = 1; i <= m; i++) {
		if (megall[i].size() > 1) {
			for(int j = 0; j < megall[i].size(); j++) {
				for(int k = j+1; k < megall[i].size(); k++) {
					el[megall[i][j]][megall[i][k]] = 1;
					el[megall[i][k]][megall[i][j]] = 1;
				}
			}
		}
	}
	return 0;
	queue<int> q;
	vector<int> tav(n+1, -1), parent(n+1, -1);

	for(int i : megall[ind]) {
		q.push(i);
		tav[i] = 1;
	}

	while(!q.empty()) {
		int u = q.front();
		q.pop();
		for(int i = 0; i < n; i++) {
			if (el[u][i]) {
				if (tav[i] == -1) {
					tav[i] = tav[u]+1;
					parent[i] = u;
					q.push(i);
				}
			}
		}
	}

	int ans = INT_MAX, mini = 0;
	for(int i : megall[erk]) {
		if (ans > tav[i]) {
			ans = tav[i];
			mini = i;
		}
	}
	cout << ans << '\n';

	vector<int> ansv;
	
	while(ans--) {
		ansv.push_back(mini);
		mini = parent[mini];
	}
	reverse(ansv.begin(), ansv.end());
	for(int x : ansv) {
		cout << x+1 << ' ';
	}

	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/40
1Hibás válasz0/03ms1828 KiB
2Hibás válasz0/04ms3036 KiB
3Hibás válasz0/23ms2256 KiB
4Hibás válasz0/23ms2496 KiB
5Hibás válasz0/23ms2916 KiB
6Hibás válasz0/23ms2724 KiB
7Hibás válasz0/23ms3200 KiB
8Hibás válasz0/23ms3560 KiB
9Hibás válasz0/24ms4036 KiB
10Hibás válasz0/24ms3964 KiB
11Hibás válasz0/23ms3760 KiB
12Hibás válasz0/24ms4632 KiB
13Hibás válasz0/24ms4796 KiB
14Hibás válasz0/24ms5076 KiB
15Időlimit túllépés0/2569ms9404 KiB
16Időlimit túllépés0/2570ms9368 KiB
17Időlimit túllépés0/2566ms9400 KiB
18Időlimit túllépés0/2566ms9488 KiB
19Hibás válasz0/24ms4972 KiB
20Hibás válasz0/24ms4928 KiB
21Hibás válasz0/24ms4736 KiB
22Hibás válasz0/24ms5176 KiB