QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#491217 | #9156. 百万富翁 | wtz | 0 | 187ms | 81672kb | C++14 | 1.7kb | 2024-07-25 17:41:40 | 2024-07-25 17:41:40 |
Judging History
answer
#include<bits/stdc++.h>
#include "richest.h"
using namespace std;
vector<int> lis[10];
vector<int> v1,v2,q,res;
int st[500010],pos=0,cnt=0;
void addquery(vector<int> v){
st[pos]=cnt; pos++;
int sz=v.size();
for(int i=0;i<sz;i++)
for(int j=i+1;j<sz;j++)
v1.push_back(v[i]),v2.push_back(v[j]),cnt++;
}
bool ok[500010];
int richer(vector<int> v,int l){
int sz=v.size();
for(int i=0;i<sz;i++) ok[i]=1;
for(int i=0;i<sz;i++)
for(int j=i+1;j<sz;j++)
if(res[l]==v[i]) ok[j]=0;
else ok[i]=0;
for(int i=0;i<sz;i++)
if(ok[i]) return v[i];
}
void div(int id,int num,int sz1,int sz2){
v1.clear(); v2.clear();
int sz=lis[id].size();
pos=0; cnt=0;
for(int i=0;i<num*sz1;i+=sz1){
q.clear();
for(int j=0;j<sz1;j++)
q.push_back(lis[id][i+j]);
addquery(q);
}
for(int i=num*sz1;i<sz;i+=sz2){
q.clear();
for(int j=0;j<sz2;j++)
q.push_back(lis[id][i+j]);
addquery(q);
}
res=ask(v1,v2);
int pos2=0;
for(int i=0;i<num*sz1;i+=sz1){
q.clear();
for(int j=0;j<sz1;j++)
q.push_back(lis[id][i+j]);
lis[id+1].push_back(richer(q,st[pos2]));
pos2++;
}
for(int i=num*sz1;i<sz;i+=sz2){
q.clear();
for(int j=0;j<sz2;j++)
q.push_back(lis[id][i+j]);
lis[id+1].push_back(richer(q,st[pos2]));
pos2++;
}
}
int smalldata(){
div(0,1,1000,0);
return lis[1][0];
}
int bigdata(){
for(int i=0;i<1000000;i++) lis[0].push_back(i);
div(0,500000,2,0);
div(1,250000,2,0);
div(2,125000,2,0);
div(3,62500,2,0);
div(4,20832,3,4);
div(5,3471,6,7);
div(6,5,18,19);
div(7,1,lis[7].size(),0);
return lis[8][0];
}
int richest(int N,int T,int S) {
if(N==1000) return smalldata();
else return bigdata();
}
Details
Tip: Click on the bar to expand more detailed information
Pretests
Pretest #1:
score: 0
Runtime Error
input:
1000 1 499500 957319859
output:
Unauthorized output
result:
Pretest #2:
score: 0
Wrong Answer
time: 187ms
memory: 81672kb
input:
1000000 20 2000000 29091473
output:
Wrong answer 4459638610240858557 0.000000 6906350380861515327
result:
points 0.0 Wrong answer
Final Tests
Test #1:
score: 0
Runtime Error
input:
1000 1 499500 957319857
output:
Unauthorized output
result:
Test #2:
score: 0
Wrong Answer
time: 178ms
memory: 81344kb
input:
1000000 20 2000000 29091471
output:
Wrong answer 4459638610240858557 0.000000 6906350380861515327
result:
points 0.0 Wrong answer