Submission #219861

#TimeUsernameProblemLanguageResultExecution timeMemory
219861peuchIslands (IOI08_islands)C++17
Compilation error
0 ms0 KiB
#include<bits/stdc++.h> using namespace std; const int MAXN = 1000100; int n; int ar[MAXN], wg[MAXN], in[MAXN], rep; int op[MAXN]; long long prof[MAXN] map<int, long long> dist; bool marc[MAXN], isCycle[MAXN]; long long ans; vector<int> rev[MAXN], rwg[MAXN]; int dfs1(int cur); long long dfs2(int cur); void getCycle(); int main(){ scanf("%d", &n); for(int i = 1; i <= n; i++){ scanf("%d %d", &ar[i], &wg[i]); rev[ar[i]].push_back(i); rev[i].push_back(ar[i]); rwg[ar[i]].push_back(wg[i]); rwg[i].push_back(wg[i]); in[ar[i]]++; } getCycle(); printf("%lld\n", ans); } int dfs1(int cur){ marc[cur] = 1; int ret = cur; for(int i = 0; i < rev[cur].size(); i++){ int viz = rev[cur][i]; if(in[viz]) continue; if(marc[viz]) continue; dist[viz] = dist[cur] + rwg[cur][i]; int aux = dfs1(viz); if(dist[aux] > dist[ret]) ret = aux; } return ret; } long long dfs2(int cur){ marc[cur] = 0; long long ret = dist[cur]; for(int i = 0; i < rev[cur].size(); i++){ int viz = rev[cur][i]; if(isCycle[viz] && rep != viz) continue; if(!marc[viz]) continue; dist[viz] = dist[cur] + rwg[cur][i]; ret = max(ret, dfs2(viz)); } return ret; } void getCycle(){ int fila[n]; int ini = 0; int fim = 0; for(int i = 1; i <= n; i++) if(in[i] == 0) fila[fim++] = i; while(ini != fim){ int cur = fila[ini++]; int viz = ar[cur]; in[viz]--; prof[viz] = max(prof[viz], prof[cur] + wg[cur]); if(in[viz] == 0) fila[fim++] = viz; } for(int i = 1; i <= n; i++){ if(in[i] == 0 || isCycle[i]) continue; int cur = i; dist[cur] = 0; long long aux = 0; long long sct = 0; while(1) { isCycle[cur] = 1; rep = cur; long long auxDist = dist[cur]; dist[cur] = 0; int x = dfs1(cur); dist[x] = 0; long long y = dfs2(x); aux = max(aux, y); dist[cur] = auxDist; sct += wg[cur]; op[ar[cur]] = cur; if(ar[cur] == i) break; dist[ar[cur]] = dist[cur] + wg[cur]; cur = ar[cur]; } cur = ar[i]; long long aux2 = prof[i] - dist[i]; long long aux3 = prof[i] + dist[i]; while(1){ if(cur == i) break; aux = max(aux, aux2 + prof[cur] + dist[cur]); aux = max(aux, aux3 + sct + prof[cur] - dist[cur]); aux2 = max(aux2, prof[cur] - dist[cur]); aux3 = max(aux3, prof[cur] + dist[cur]); cur = ar[cur]; } cur = op[op[i]]; aux2 = prof[ar[cur]] + dist[ar[cur]]; aux3 = prof[ar[cur]] - dist[ar[cur]]; while(1){ if(cur == op[i]) break; aux = max(aux, aux2 + prof[cur] - dist[cur]); aux = max(aux, aux3 + sct + prof[cur] + dist[cur]); aux2 = max(aux2, prof[cur] + dist[cur]); aux3 = max(aux3, prof[cur] - dist[cur]); cur = op[cur]; } ans += aux; dist.clear(); } }

Compilation message (stderr)

islands.cpp:10:1: error: expected initializer before 'map'
 map<int, long long> dist;
 ^~~
islands.cpp: In function 'int dfs1(int)':
islands.cpp:37:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0; i < rev[cur].size(); i++){
                 ~~^~~~~~~~~~~~~~~~~
islands.cpp:41:3: error: 'dist' was not declared in this scope
   dist[viz] = dist[cur] + rwg[cur][i];
   ^~~~
islands.cpp:41:3: note: suggested alternative: 'dfs2'
   dist[viz] = dist[cur] + rwg[cur][i];
   ^~~~
   dfs2
islands.cpp: In function 'long long int dfs2(int)':
islands.cpp:50:18: error: 'dist' was not declared in this scope
  long long ret = dist[cur];
                  ^~~~
islands.cpp:50:18: note: suggested alternative: 'dfs2'
  long long ret = dist[cur];
                  ^~~~
                  dfs2
islands.cpp:51:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0; i < rev[cur].size(); i++){
                 ~~^~~~~~~~~~~~~~~~~
islands.cpp: In function 'void getCycle()':
islands.cpp:71:3: error: 'prof' was not declared in this scope
   prof[viz] = max(prof[viz], prof[cur] + wg[cur]);
   ^~~~
islands.cpp:71:3: note: suggested alternative: 'feof'
   prof[viz] = max(prof[viz], prof[cur] + wg[cur]);
   ^~~~
   feof
islands.cpp:77:3: error: 'dist' was not declared in this scope
   dist[cur] = 0;
   ^~~~
islands.cpp:77:3: note: suggested alternative: 'dfs2'
   dist[cur] = 0;
   ^~~~
   dfs2
islands.cpp:97:20: error: 'prof' was not declared in this scope
   long long aux2 = prof[i] - dist[i];
                    ^~~~
islands.cpp:97:20: note: suggested alternative: 'feof'
   long long aux2 = prof[i] - dist[i];
                    ^~~~
                    feof
islands.cpp: In function 'int main()':
islands.cpp:21:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &n);
  ~~~~~^~~~~~~~~~
islands.cpp:23:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d %d", &ar[i], &wg[i]);
   ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~