# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
125116 | khulegub | 곤돌라 (IOI14_gondola) | C++14 | 23 ms | 2528 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "gondola.h"
#include <bits/stdc++.h>
#define pb push_back
#define mp make_pair
#define xx first
#define yy second
using namespace std;
typedef long long i64;
typedef pair<int, int> pii;
int valid(int n, int arr[]){
vector<pii> rep;
vector<pii> v;
for (int i = 0; i < n; i++){
arr[i]--;
// cout << arr[i] << ' ';
if (arr[i] >= n){
rep.pb(mp(arr[i] - n, i) );
}
else v.pb(mp(i, arr[i]) );
}
if(v.size() > 0){
int diff = v[0].yy - v[0].xx;
int end = (n - 1) - diff;
int diff2 = diff - n;
// cout << diff2;
int vn = v.size();
for (int i = 0; i < vn; i++){
if (v[i].xx <= end){
if (v[i].yy - v[i].xx != diff) return 0;
}
else{
if (v[i].yy - v[i].xx != diff2) return 0;
}
}
}
sort(rep.begin(), rep.end());
for(int i = 0; i + 1 < rep.size(); i++){
if(rep[i].xx == rep[i + 1].xx) return 0;
}
// cout << "veve";
return 1;
}
//----------------------
int replacement(int n, int arr[], int repl[]){
vector<pii> rep;
vector<pii> v;
for (int i = 0; i < n; i++){
arr[i]--;
if (arr[i] >= n){
rep.pb( mp(arr[i] - n, i) );
}
else {
v.pb( mp(i, arr[i]) );
}
}
sort(rep.begin(), rep.end() );
if(v.size() > 0){
int diff = v[0].yy - v[0].xx;
int end = (n - 1) - diff;
int diff2 = diff - n;
int repsz = 0;
int last = 0;
for(int i = 0; i < rep.size(); i++){
for(int j = last; j <= rep[i].xx; j++){
int tmp;
if(j == last){
if(rep[i].yy <= end) tmp = rep[i].yy + diff;
else tmp = rep[i].yy + diff2;
}
else{
tmp = n + j - 1;
}
tmp++;
repl[j] = tmp;
repsz++;
}
last = rep[i].xx + 1;
}
return repsz;
// cout << diff2;
}
else{ //wtf evdreegu neg ch bdggu nasss
int repsz = 0;
int last = 0;
for(int i = 0; i < rep.size(); i++){
for(int j = last; j <= rep[i].xx; j++){
int tmp;
if(j == last){
tmp = rep[i].yy;
}
else{
tmp = n + j - 1;
}
tmp++;
// cout << tmp << ' ';
repl[j] = tmp;
repsz++;
}
last = rep[i].xx + 1;
}
return repsz;
}
}
//----------------------
int countReplacement(int n, int inputSeq[])
{
return -3;
}
컴파일 시 표준 에러 (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... |