Submission #57709

#TimeUsernameProblemLanguageResultExecution timeMemory
57709FLDutchmanGondola (IOI14_gondola)C++14
60 / 100
40 ms3092 KiB
#include "gondola.h" #include <bits/stdc++.h> using namespace std; typedef int INT; #define mp make_pair #define pb push_back #define fst first #define snd second #define int long long #define MMAX 16384 #define fast_io() ios::sync_with_stdio(false) #define FOR(i, l, r) for(int i = (l); i < (r); i++) typedef long long ll; typedef pair<ll, ll> ii; typedef vector<int> vi; typedef vector<ii> vii; typedef vector<vi> vvi; typedef set<int> si; typedef double ld; typedef pair<ld, ld> dd; const ll INF = 1000000000000000000LL; const int NMAX = 1e5+4; const int mod = 1e9+7; const ld eps = 1e-10; const ld PI = acos(-1); INT valid(INT n, INT inputSeq[]){ int k = -1; FOR(i, 0, n) if(inputSeq[i] <= n) {k = i; break;} if(k == -1) { vi tmp; FOR(i, 0, n) tmp.pb(inputSeq[i]); sort(tmp.begin(), tmp.end()); FOR(i, 0, n-1) if(tmp[i] == tmp[i+1]) return false; return true; } int pos = (k-inputSeq[k]+1+n)%n; rotate(inputSeq, inputSeq+pos, inputSeq+n); vi tmp; FOR(i, 0, n) tmp.pb(inputSeq[i]); sort(tmp.begin(), tmp.end()); FOR(i, 0, n-1) if(tmp[i] == tmp[i+1]) return false; FOR(i, 0, n){ if(inputSeq[i] <= n and inputSeq[i] != i+1) return false; } return true; } INT replacement(INT n, INT gondolaSeq[], INT replacementSeq[]){ valid(n, gondolaSeq); vii seq(n); FOR(i, 0, n) seq[i] = {gondolaSeq[i], i+1}; sort(&seq[0], &seq[n]); int j = n+1; vi ret; FOR(i, 0, n){ while(seq[i].fst != seq[i].snd) ret.pb(seq[i].snd), seq[i].snd = j++; } FOR(i, 0, ret.size()) replacementSeq[i] = ret[i]; return ret.size(); } INT countReplacement(INT n, INT inputSeq[]){ if(!valid(n, inputSeq)) return 0; int res = 1; sort(inputSeq, inputSeq+n); int j = n+1; bool all = 1; FOR(i, 0, n){ if(inputSeq[i] <= n) { all = 0; continue; } while(inputSeq[i] > j) res = res * (n-i) % mod, j++; j++; } if(all) res = res * n % mod; return res; }

Compilation message (stderr)

gondola.cpp: In function 'INT replacement(INT, INT*, INT*)':
gondola.cpp:14:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
 #define FOR(i, l, r) for(int i = (l); i < (r); i++)
                                         ^
gondola.cpp:63:5: note: in expansion of macro 'FOR'
     FOR(i, 0, ret.size()) replacementSeq[i] = ret[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...