QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#508221 | #9156. 百万富翁 | H17 | 100 ✓ | 4595ms | 112428kb | C++14 | 2.1kb | 2024-08-07 09:52:59 | 2024-08-07 09:53:00 |
Judging History
answer
#include<bits/stdc++.h>
#include"richest.h"
using namespace std;
vector<int>ask(vector<int>a,vector<int>b);//声明
vector<int>get_division(vector<int>v,vector<int>division){//根据序列划分
static int sum,tot,lmax;
static vector<int>ret,a,b,c;
static map<pair<int,int>,int>mp;
ret.clear();
a.clear(),b.clear(),mp.clear();
sum=tot=0;
for(auto p:division){//当前p个一块
for(int i=sum;i<sum+p;i++)
for(int j=i+1;j<sum+p;j++)
a.push_back(v[i]),b.push_back(v[j]),mp[{v[i],v[j]}]=tot++;//两两询问
sum+=p;
}
c=ask(a,b);
sum=0;
for(auto p:division){
lmax=v[sum];
for(int i=sum+1;i<sum+p;i++)
lmax=c[mp[{lmax,v[i]}]];
ret.push_back(lmax);//取当前块最大值
sum+=p;
}
return ret;
}
void test(vector<int>k){
for(auto t:k)
cerr<<t<<' ';
cerr<<'\n';
}
int richest(int n,int t,int s){
if(n==1000){
vector<int>v;
for(int i=0;i<n;i++)
v.push_back(i);
return get_division(v,vector<int>(1,1000))[0];//一次性搞完
}
static vector<int>k,divi;
k.clear(),divi.clear();
for(int i=0;i<n;i++)
k.push_back(i);
for(int i=0;i<500000;i++)//1
divi.push_back(2);
k=get_division(k,divi);
divi.clear();
for(int i=0;i<250000;i++)//2
divi.push_back(2);
k=get_division(k,divi);
divi.clear();
for(int i=0;i<125000;i++)//3
divi.push_back(2);
k=get_division(k,divi);
divi.clear();
for(int i=0;i<62500;i++)//4
divi.push_back(2);
k=get_division(k,divi);
divi.clear();
divi.push_back(4);
for(int i=0;i<20832;i++)//5
divi.push_back(3);
k=get_division(k,divi);
divi.clear();
divi.push_back(7);
for(int i=0;i<3471;i++)//6
divi.push_back(6);
k=get_division(k,divi);
divi.clear();
for(int i=0;i<5;i++)//7
divi.push_back(18);
for(int i=0;i<178;i++)
divi.push_back(19);
k=get_division(k,divi);
return get_division(k,vector<int>(1,183))[0];
}
Details
Tip: Click on the bar to expand more detailed information
Pretests
Pretest #1:
score: 15
Accepted
time: 1566ms
memory: 55628kb
input:
1000 1 499500 957319859
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Pretest #2:
score: 85
Accepted
time: 4481ms
memory: 112428kb
input:
1000000 20 2000000 29091473
output:
Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944 7610580723948932399 1.000000 1331569654267968081
result:
points 1.0 Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944
Final Tests
Test #1:
score: 15
Accepted
time: 1583ms
memory: 53752kb
input:
1000 1 499500 957319857
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Test #2:
score: 85
Accepted
time: 4595ms
memory: 109536kb
input:
1000000 20 2000000 29091471
output:
Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944 7610580723948932399 1.000000 1331569654267968081
result:
points 1.0 Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944