# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
584881 | Mazaalai | Gondola (IOI14_gondola) | C++17 | 8 ms | 596 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#include "gondola.h"
#define ALL(x) x.begin(),x.end()
#define LLA(x) x.rbegin(),x.rend()
#define pb push_back
using namespace std;
using PII = pair <int, int>;
int valid(int n, int nums[]) {
int mini = 0;
for (int i = 1; i < n; i++)
if (nums[i] < nums[mini]) mini = i;
int st = nums[mini];
vector <int> tmp;
for (int i = 0; i < n; i++) {
int j = (mini + i) % n;
if (nums[j] == st+i) continue;
if (nums[j] > n) tmp.pb(nums[j]);
if (nums[j] <= n) return 0;
}
sort(ALL(tmp));
for (int i = 1; i < tmp.size(); i++)
if (tmp[i] == tmp[i-1]) return 0;
return 1;
}
int replacement(int n, int nums[], int res[]) {
int mini = 0, cp[n];
for (int i = 0; i < n; i++) {
nums[i]--;
if (nums[i] < nums[mini]) mini = i;
}
vector <PII> tmp;
int st = nums[mini];
cp[mini] = st;
for (int i = 0; i < n; i++) {
int j = (mini + i) % n;
cp[(j+1)%n] = (cp[j]+1)%n;
if (nums[j] == st+i && nums[j] <= n) continue;
tmp.pb({nums[j], j});
}
sort(ALL(tmp));
int ptr = n, x = 0;
for (auto [a, b] : tmp) {
while(1) {
res[x++] = cp[b]+1;
cp[b] = ptr;
if (ptr++ == a) break;
}
}
return x;
}
int countReplacement(int n, int inputSeq[]) {
return -3;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |