QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#822367 | #9914. 前往何方 | hewanying | 0 | 1770ms | 152560kb | C++14 | 1.9kb | 2024-12-20 11:03:40 | 2024-12-20 11:03:40 |
Judging History
你现在查看的是测评时间为 2024-12-20 11:03:40 的历史记录
- [2024-12-20 11:03:40]
- 提交
answer
#include "wheretoreach.h"
#include <bits/stdc++.h>
using namespace std;
#define pb push_back
const int N=1e4+5;
int sz[N],fa[N];
bool vis[N];
struct Nod{
int v,id;
bool operator <(const Nod &a) const{return v>a.v;}
};
void sol(vector<int> V){
int m=(int)V.size(),rt=0;
if(m==1) return;
// cerr<<"sol : ";
// for(auto i:V) cerr<<i<<" ";
// cerr<<endl;
for(auto i:V) add(i);
for(auto i:V){
sz[i]=remove(i),add(i),vis[i]=0,fa[i]=0;
if(sz[i]<=m/2) rt=i;
}
// cerr<<"rt = "<<rt<<endl;
vector<Nod> cur;
vector<vector<int> > nxt;
for(auto i:V) if(i!=rt) sz[i]=m-sz[i],cur.pb({sz[i],i});
sort(cur.begin(),cur.end());
int mx=cur[0].v;
remove(rt);
vector<int> nw;nw.pb(cur[0].id),vis[cur[0].id]=1,report(rt,cur[0].id);
for(int i=1;i<(int)cur.size();i++){
if(cur[i].v==cur[0].v) remove(cur[i].id);
else if(remove(cur[i].id)!=mx) add(cur[i].id),nw.pb(cur[i].id),vis[cur[i].id]=1;
}
for(int i:V) if(!vis[i]) add(i);
vector<int> son;
mx=m;add(rt);
for(auto i:cur) if(!vis[i.id]){
int tmp=remove(i.id);
if(tmp<mx) mx=tmp,son.pb(i.id),nxt.pb({i.id}),vis[i.id]=1,report(rt,i.id);
}
for(int i=0;i<=__lg((int)son.size()-1);i++){
int ret=0;
for(auto j:cur) if(!vis[j.id]) ret=add(j.id);
for(int j=0;j<(int)son.size();j++) if(j>>i&1) ret=add(j);
for(auto j:cur) if(!vis[j.id]){
if(remove(j.id)<ret) fa[j.id]|=(1<<i);
add(j.id);
}
for(auto j:cur) if(!vis[j.id]) remove(j.id);
for(int j=0;j<(int)son.size();j++) if(j>>i&1) remove(j);
}
nxt.pb(nw);
for(auto j:cur) if(!vis[j.id]) nxt[fa[j.id]].pb(j.id);
for(int i:nw) remove(i);
remove(rt);
for(auto i:nxt) sol(i);
}
void solve(int n){
vector<int> V;
for(int i=1;i<=n;i++) V.pb(i);
sol(V);
return;
}
/*
g++ implementer.cpp wheretoreach.cpp -o 1 -O2 --std=c++14 -lm
*/
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 74ms
memory: 5088kb
input:
500 310 77 468 235 218 93 58 406 223 334 159 243 204 48 144 107 492 288 447 165 102 407 340 299 450 126 140 234 209 62 111 204 453 306 4 476 126 358 183 317 360 489 149 158 232 22 326 372 92 383 410 24 199 14 401 480 69 329 192 167 409 152 426 354 435 60 146 404 334 187 208 305 123 55 30 79 469 72 2...
output:
Unauthorized output
result:
wrong answer I am not my biggest fan. :(
Subtask #2:
score: 0
Wrong Answer
Test #9:
score: 0
Wrong Answer
time: 1090ms
memory: 20572kb
input:
2500 887 818 1296 878 1605 2107 803 2410 1919 1135 860 1160 1364 2414 1375 500 894 2173 2322 2449 211 1732 1821 573 413 1556 1574 1977 709 162 2002 1577 1626 1895 1563 688 2151 2293 661 69 317 1170 2335 1549 1481 1349 1500 779 1593 735 1824 2380 639 2334 1496 2335 1956 1384 2476 1583 1035 163 720 70...
output:
Unauthorized output
result:
wrong answer I am not my biggest fan. :(
Subtask #3:
score: 0
Wrong Answer
Test #17:
score: 0
Wrong Answer
time: 1770ms
memory: 152560kb
input:
10000 6139 8917 131 5800 5366 5247 1298 5035 3966 3518 4889 7202 6547 1919 5829 9494 8012 6029 3868 6403 1909 8116 5734 6122 2683 4779 9275 6673 7433 9042 7646 2032 3547 6306 1943 8382 4061 6428 8240 3548 460 2795 3451 4320 5904 6627 8709 7621 8706 3534 748 4873 8101 4261 5359 3304 6254 4687 6492 53...
output:
Unauthorized output
result:
wrong answer I am not my biggest fan. :(