| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
|---|---|---|---|---|---|---|---|
| 1282565 | repmann | 곤돌라 (IOI14_gondola) | C++20 | 0 ms | 0 KiB |
#include <bits/stdc++.h>
using namespace std;
int N;
int A[200000];
int valid(int n, int a[])
{
N = n;
set <int> SET;
for(int i = 0; i < N; i++) if(!SET.insert(a[i]).second) return 0;
for(int i = 0; i < N; i++) A[i] = A[i + N] = a[i];
int index = 0;
for(int i = 1; i < N; i++) if(A[i] < A[index]) index = i;
if(A[index] > N) return 1;
for(int i = index; i < (index + N); i++)
{
if((A[i] <= N) && (A[index] != (A[i] - (i - index)))) return 0;
}
return 1;
}
