#include <bits/stdc++.h> using namespace std; int main (){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n, przejscia=0, akt=0, podruz=0; cin >> n; vector<vector<int>> tab(n+1); tab[0]={0}; for (int i=1; i<=n; i++){ int ile; cin >> ile; if (ile==0) tab[i].push_back(0); for (int j=0; j<ile; j++){ int z; cin >> z; tab[i].push_back(z); } } for (int k=1; k<=n; k++){ podruz=0; for (int i=1; i<=n; i++){ int rozm=tab[i].size(); for (int j=0; j<rozm; j++){ if (tab[i][j]!=i) podruz=1; if (tab[i][j]==0){ tab[i].erase(tab[i].begin()+j); tab[i].push_back(i); if (podruz==1) przejscia+=i+1; podruz=0; i=100; break; } if (tab[i][j]==i){ if (podruz==1) przejscia++; podruz=0; continue; } akt=tab[i][j]; tab[akt].push_back(akt); tab[i].erase(tab[i].begin()+j); //przejscia++; i=akt-1; break; } } } cout << przejscia; return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | #include <bits/stdc++.h> using namespace std; int main (){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n, przejscia=0, akt=0, podruz=0; cin >> n; vector<vector<int>> tab(n+1); tab[0]={0}; for (int i=1; i<=n; i++){ int ile; cin >> ile; if (ile==0) tab[i].push_back(0); for (int j=0; j<ile; j++){ int z; cin >> z; tab[i].push_back(z); } } for (int k=1; k<=n; k++){ podruz=0; for (int i=1; i<=n; i++){ int rozm=tab[i].size(); for (int j=0; j<rozm; j++){ if (tab[i][j]!=i) podruz=1; if (tab[i][j]==0){ tab[i].erase(tab[i].begin()+j); tab[i].push_back(i); if (podruz==1) przejscia+=i+1; podruz=0; i=100; break; } if (tab[i][j]==i){ if (podruz==1) przejscia++; podruz=0; continue; } akt=tab[i][j]; tab[akt].push_back(akt); tab[i].erase(tab[i].begin()+j); //przejscia++; i=akt-1; break; } } } cout << przejscia; return 0; } |