結果
| 問題 |
No.2085 Directed Complete Graph
|
| ユーザー |
momoyuu
|
| 提出日時 | 2023-04-23 02:21:03 |
| 言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 162 ms / 2,000 ms |
| コード長 | 1,129 bytes |
| コンパイル時間 | 3,640 ms |
| コンパイル使用メモリ | 250,328 KB |
| 実行使用メモリ | 25,580 KB |
| 平均クエリ数 | 2533.76 |
| 最終ジャッジ日時 | 2024-11-07 12:32:11 |
| 合計ジャッジ時間 | 6,954 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 15 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
int main(){
int n;
cin>>n;
deque<int> que;
int l = 1;
int r = 2;
cout<<"? 1 2"<<endl;
int t;
cin>>t;
if(t==1);
else swap(l,r);
que.push_back(l);
que.push_back(r);
int ni = 3;
for(;ni<=n;ni++){
int l = -1;
int r = que.size();
while(r-l>1){
int mid = (r+l)/2;
cout<<"? "<<que[mid]<<" "<<ni<<endl;
int op;
cin>>op;
if(op==-1) assert(false);
if(op==1) l = mid;
else r = mid;
}
if(r==0){
que.push_front(ni);
continue;
}
if(l==que.size()-1){
que.push_back(ni);
continue;
}
deque<int> nxt;
for(int i = 0;i<=l;i++) nxt.push_back(que[i]);
nxt.push_back(ni);
for(int i = r;i<que.size();i++) nxt.push_back(que[i]);
swap(nxt,que);
}
cout<<"!"<<endl;
cout<<n-1<<endl;
for(int i = 0;i<n;i++){
if(i!=0) cout<<" ";
cout<<que[i];
}
cout<<endl;
}
momoyuu