Submission #1064448

#TimeUsernameProblemLanguageResultExecution timeMemory
1064448woodGondola (IOI14_gondola)C++17
10 / 100
9 ms1848 KiB
#include "gondola.h"
#include <bits/stdc++.h>
using namespace std;
#define vi vector<int>
#define pb push_back

int valid(int n, int inputSeq[])
{
	vi small; set<int> big;
	for(int i = 0; i<n; i++){
		if(inputSeq[i]<n) small.pb(inputSeq[i]); 
		else big.insert(inputSeq[i]);
	}
	int bad = 0;
	for(int i = 0; i<small.size()-1; i++){
		bad+=small[i+1]<small[i];
	}
	bad+=small[n-1]>small[0];
	if(bad>1) return 0;
	for(int x : big){
		if(x==*big.rbegin()) continue;
		if(!big.count(x+1)) return 0;
	}
	return 1;
}

//----------------------

int replacement(int n, int gondolaSeq[], int replacementSeq[])
{
  return -2;
}

//----------------------

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

Compilation message (stderr)

gondola.cpp: In function 'int valid(int, int*)':
gondola.cpp:15:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   15 |  for(int i = 0; i<small.size()-1; 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...