제출 #162040

#제출 시각아이디문제언어결과실행 시간메모리
162040oolimry곤돌라 (IOI14_gondola)C++14
55 / 100
51 ms4728 KiB
#include "gondola.h"
#include <bits/stdc++.h>
using namespace std;
int valid(int n, int arr[]) {
	set<int> sset;
    for(int i = 0;i < n;i++){
		sset.insert(arr[i]);
	}
	if(sset.size() != n) return 0;
	
	int anchor = -1;
	
	for(int i = 0;i < n;i++){
		if(arr[i] <= n){
			anchor = (arr[i] - i + n) % n;
			break;
		}
	}
	
	if(anchor == -1) return 1;
	
	for(int i = 0;i < n;i++){
		if(arr[i] <= n){
			if(arr[i] % n != (anchor + i) % n){
				return 0;
			}
		}
	}
	return 1;
}

int replacement(int n, int arr[], int replacementSeq[]) {
	
	int anchor = 0;
	int ori[n];
	map<int,int> m;
	set<int> s;
    for(int i = 0;i < n;i++){
		if(arr[i] <= n){
			anchor = (arr[i] - i + n) % n;
			break;
		}
	}
	
	int maxv = 0;
	int maxpos = 0;
	for(int i = 0;i < n;i++){
		ori[i] = (anchor+i) % n;
		if(ori[i] == 0) ori[i] = n;
		if(arr[i] > maxv){
			maxv = arr[i];
			maxpos = i;
		}
		if(arr[i] > n){
			m[arr[i]] = i;
		}
	}
	
	
	int cnt = 0;
	for(int r = n+1;r <= maxv;r++){
		int rindex = 0;
		if(m.find(r) == m.end()){
			rindex = maxpos;
		}
		else{
			rindex = m[r];
		}
		
		replacementSeq[cnt] = ori[rindex];
		ori[rindex] = r;
		cnt++; 
	}
	
	return cnt;
	
}

int countReplacement(int n, int inputSeq[]) {
    return 0;
}

컴파일 시 표준 에러 (stderr) 메시지

gondola.cpp: In function 'int valid(int, int*)':
gondola.cpp:9:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  if(sset.size() != n) return 0;
     ~~~~~~~~~~~~^~~~
#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...