제출 #634749

#제출 시각아이디문제언어결과실행 시간메모리
634749tvladm2009Bosses (BOI16_bosses)C++14
0 / 100
1 ms468 KiB
#include <iostream> #include <vector> #include <queue> #include <string.h> #define int long long using namespace std; const int MAX_N = 5 * 1e3; const int INF = (1LL << 60); int dist[MAX_N + 1]; bool viz[MAX_N + 1]; vector<int> g[MAX_N + 1]; int n; int bfs(int start) { memset(dist, 0, sizeof(dist)); memset(viz, 0, sizeof(viz)); queue<int> q; q.push(start); int cost = 0; while (!q.empty()) { int u = q.front(); q.pop(); viz[u] = true; for (int v : g[u]) { if (!viz[v]) { dist[v] = dist[u] + 1; cost += dist[v]; q.push(v); } } } for (int i = 1; i <= n; i++) { if (!viz[i]) { return INF; } } return cost; } signed main() { cin >> n; for (int i = 1; i <= n; i++) { int k; cin >> k; for (int j = 1; j <= k; j++) { int x; cin >> x; g[x].push_back(i); } } int answer = INF; for (int i = 1; i <= n; i++) { answer = min(answer, bfs(i) + n); } cout << answer; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...