Submission #301226

#TimeUsernameProblemLanguageResultExecution timeMemory
301226joseacazComparing Plants (IOI20_plants)C++17
0 / 100
4081 ms62712 KiB
#include "plants.h" #include <bits/stdc++.h> #define pb push_back #define all(x) x.begin(), x.end() using namespace std; typedef long long ll; typedef vector<int> vi; const int MAXN = 2e5 + 5; int N, k, vis[MAXN], memo[5005][5005]; vi r, Graph[MAXN]; void sub(int idx) { for(int i = 1; i < k; i++) { int id = ((idx - i)%N + N)%N; if(r[id] > 0) { r[id]--; if(r[id] == 0) Graph[idx].pb(id); } } } int getnext(int idx) { for(int i = 1; i < N; i++) { int id = ((idx + i)%N + N)%N; if(i < k && !vis[id]) Graph[idx].pb(id); if(r[id] == 0 && !vis[id]) return id; } return idx; } void dfs(int root, int node) { memo[root][node] = 1; for(auto i : Graph[node]) dfs(root, i); } void init(int _k, vi _r) { k = _k; swap(r, _r); N = r.size(); int maxIdx = 0; for(int i = 0; i < N; i++) { if(r[i] != 0) continue; int maxim = 1; for(int j = 1; j < k; j++) { int id = ((i - j)%N + N)%N; if(r[id] == 0) maxim = 0; } if(maxim) maxIdx = i; } while(!vis[maxIdx]) { vis[maxIdx] = 1; sub(maxIdx); maxIdx = getnext(maxIdx); } for(int i = 0; i < N; i++) dfs(i, i); return; } int compare_plants(int x, int y) { if(memo[x][y]) return 1; else if(memo[y][x]) return -1; return 0; }

Compilation message (stderr)

plants.cpp: In function 'void init(int, vi)':
plants.cpp:76:5: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
   76 |     for(int i = 0; i < N; i++)
      |     ^~~
plants.cpp:78:2: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
   78 |  return;
      |  ^~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...