이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#define maxn 160
int resp[maxn];
using namespace std;
int teste(int cur,int ini,int fim){
vector<int> t;
for(int i=ini;i<=fim;i++){
if(resp[i]==0&&i!=cur&&i!=-cur){
t.push_back(i);
}
}
if(cur>0) t.push_back(cur);
if(t.size()==1) return 1;
cout<<t.size()<<" ";
for(int i=0;i<t.size();i++){
cout<<t[i]<<" ";
}
cout<<endl;
int resp;
cin>>resp;
return resp;
}
void findc(int cur,int ini,int fim){
int r1=0,r2=0;
r1=teste(cur,ini,fim);
if(r1==1){
for(int i=ini;i<=fim;i++){
if(resp[i]==0) resp[i]=resp[cur];
}
}
else r2=teste(-cur,ini,fim);
if(r1==r2){
int m=(ini+fim)/2;
findc(cur,ini,m);
findc(cur,m+1,fim);
}
}
int main(){
int n;
cin>>n;
int c=1;
for(int i=1;i<=n;i++){
if(resp[i]==0){
resp[i]=c;
findc(i,1,n);
c++;
}
}
cout<<"0"<<" ";
for(int i=1;i<=n;i++){
cout<<resp[i]<<" ";
}
}
컴파일 시 표준 에러 (stderr) 메시지
carnival.cpp: In function 'int teste(int, int, int)':
carnival.cpp:15:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i=0;i<t.size();i++){
~^~~~~~~~~
# | 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... |