Submission #52448

#TimeUsernameProblemLanguageResultExecution timeMemory
52448shoemakerjoGondola (IOI14_gondola)C++14
75 / 100
92 ms6488 KiB
#include <bits/stdc++.h> #include "gondola.h" using namespace std; #define ll long long #define pii pair<int, int> const int mod = 1000000009; int modpow(int base, int p) { if (p == 0) return 1; if (p & 1) { int tmp = modpow(base, p-1); return (tmp*1LL*base)%mod; } int tmp = modpow(base, p/2); return (tmp*1LL*tmp)%mod; } int valid(int n, int inputSeq[]) { int minval = n+1; int minind = 0; set<int> seen; for (int i = 0; i < n; i++) { if (inputSeq[i] < minval) { minval = inputSeq[i]; minind = i; } if (seen.count(inputSeq[i]) > 0) return 0; seen.insert(inputSeq[i]); } if (minval > n) return 1; //i think this is fine then int cur = minind; int ivals[n]; int cv = minval; //cannot appear after something that is greater than me and still less than n int maxv = -1; for (int i = 0; i < n; i++) { ivals[cur] = cv; cur = (cur+1)%n; cv = (cv+1)%n; if (cv == 0) cv += n; } for (int i = 0; i < n; i++) { if (inputSeq[i] <= n && inputSeq[i] != ivals[i]) { return 0; } } return 1; //nothing was bad enough to return 0 } //---------------------- int replacement(int n, int gondolaSeq[], int replacementSeq[]) { //find a valid replacement sequence int sz = 0; //size of the answer int lowbelow = -1; int lowind = -1; int maxval = -1; map<int, int> ch; int maxind = -1; int cvals[n]; for (int i = 0; i < n; i++) { if (gondolaSeq[i] <= n) { if (gondolaSeq[i] < lowbelow || lowbelow == -1) { lowbelow = gondolaSeq[i]; lowind = i; } } else { //the value is greater than n ch[gondolaSeq[i]] = i; //this index must be the one replaced at its final value } if (gondolaSeq[i] > maxval) { maxval = gondolaSeq[i]; maxind = i; } } //do not use a vector for ans just add stuff to replacementSeq as you go and increment sz int cv; if (lowind != -1) cv = gondolaSeq[lowind]; int ci = lowind; if (lowind == -1) { ci = 0; cv = 1; } for (int i = 0; i < n; i++) { cvals[ci] = cv; //current values ci = (ci+1)%n; cv = (cv+1)%n; if (cv == 0) cv += n; } for (int i = n+1; i <= maxval; i++) { if (ch.count(i) != 0) { //this is a final value for something replacementSeq[sz++] = cvals[ch[i]]; cvals[ch[i]] = i; } else { replacementSeq[sz++] = cvals[maxind]; cvals[maxind] = i; //becomes the new value } } return sz; } //---------------------- int countReplacement(int n, int inputSeq[]) { if (valid(n, inputSeq) == 0) { //just add this in there return 0; } int ans = 1; vector<int> aftn; aftn.push_back(n); int minv = 1234567890; for (int i = 0; i < n; i++) { if (inputSeq[i] > n) { aftn.push_back(inputSeq[i]); } minv = min(minv, inputSeq[i]); } sort(aftn.begin(), aftn.end()); for (int i = 1; i < aftn.size(); i++) { int rep = aftn[i]-aftn[i-1]-1; //how many times we need to repeat this int ops = aftn.size() - i; //cout << "here: " << aftn[i] << " rep, ops: " << rep << " " << ops << endl; ans = (ans * 1LL * modpow(ops, rep))%mod; } if (minv > n) { //we are allowed to replace anything from the first set to get to n+1 ans = (ans*n)%mod; } return ans; }

Compilation message (stderr)

gondola.cpp: In function 'int valid(int, int*)':
gondola.cpp:37:6: warning: unused variable 'maxv' [-Wunused-variable]
  int maxv = -1;
      ^~~~
gondola.cpp: In function 'int countReplacement(int, int*)':
gondola.cpp:129:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for (int i = 1; i < aftn.size(); i++) {
                  ~~^~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...