Submission #995207

#TimeUsernameProblemLanguageResultExecution timeMemory
995207alex_2008Comparing Plants (IOI20_plants)C++14
0 / 100
4 ms4700 KiB
#include "plants.h" #include <iostream> #include <cmath> #include <vector> #include <algorithm> #include <set> #include <map> typedef long long ll; using namespace std; const int N = 2e5 + 10; int r[N], perm[N]; int val[N]; int n, k; void init(int K, vector<int> R) { k = K; n = (int)R.size(); for (int i = 1; i <= n; i++) { r[i] = R[i]; } for (int i = n; i >= 1; i--) { int j; for (j = 1; j <= n; j++) { bool ch = true; if (r[j] != (k - 1)) continue; for (int l = j + k; l <= n; l++) { if (r[l] == (k - 1)) { ch = false; } } for (int l = 1; l < i; l++) { if (r[l] == (k - 1)) { ch = false; } } if (ch) { perm[j] = i; for (int l = max(1, (j - k + 1)); l < j; l++) { r[l]++; } if ((i - k + 1) < 1) { int mnac = (k - 1) - (j - 1); for (int l = n; l > n - mnac; l--) { r[l]--; } } break; } } if (j > n) { throw "esim"; } } } int compare_plants(int x, int y) { if (perm[x] > perm[y]) return 1; return -1; } /* int main() { } */
#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...