제출 #30350

#제출 시각아이디문제언어결과실행 시간메모리
30350Nikefor곤돌라 (IOI14_gondola)C++98
15 / 100
16 ms3396 KiB
#include "gondola.h" #include <vector> #include <algorithm> #include <cstdio> #define mod 1000000009 using namespace std; long long us(int x, int y) { if(x==0) return 1; if(y==0) return 1; if(y==1) return x%mod; if(y&1) return (us(x,y>>1) * us(x, (y>>1)+1))%mod; return (us(x, y>>1)*us(x,y>>1))%mod; } int valid(int n, int inputSeq[]) { vector<int> used; for (int i = 0; i < n-1; ++i) { used.push_back(inputSeq[i]); if(inputSeq[i]<=n and inputSeq[i+1]<=n and inputSeq[i+1]!=1 and inputSeq[i]>inputSeq[i+1]) return 0; } if(inputSeq[n-1]<=n and inputSeq[0]<=n and inputSeq[n-1]>inputSeq[0]) return 0; used.push_back(inputSeq[n-1]); sort(used.begin(), used.end()); for(int i=0; i<used.size()-1; i++) if(used[i]==used[i+1]) return 0; return 1; } //---------------------- int replacement(int n, int gondolaSeq[], int replacementSeq[]) { return -2; } //---------------------- int countReplacement(int n, int inputSeq[]) { //for(int i=0 ; i<20; i++) printf("%d\n",us(2,i) ); int res = 1, ctr=0; //if(!valid(n, inputSeq)) return 0; bool flag = true; vector<int> v; for (int i = 0; i < n; ++i) { if(inputSeq[i]>n) flag = false; if(i!=n-1 and inputSeq[i+1] != (inputSeq[i]+1) and inputSeq[i+1]!=1) flag = false; if(inputSeq[i]>n) { ctr++; v.push_back(inputSeq[i]); } } sort(v.begin(), v.end()); if(flag) return 1; int last = n+1; for(int i= 0; i<v.size(); i++) { res*= us(v[i]-last, v.size()-i);; last = v[i]+1; } return res; }

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

gondola.cpp: In function 'int valid(int, int*)':
gondola.cpp:27:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i=0; i<used.size()-1; i++) if(used[i]==used[i+1]) return 0;
                 ^
gondola.cpp: In function 'int countReplacement(int, int*)':
gondola.cpp:58:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i= 0; i<v.size(); 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...