QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#500474 | #9156. 百万富翁 | mirkdang | 0 | 0ms | 0kb | C++14 | 1.3kb | 2024-08-01 12:44:40 | 2024-08-01 12:44:41 |
answer
#include<bits/stdc++.h>
#include"richest.h"
using namespace std;
int x[8]={500000,250000,125000,62496,20832,3472,183,1};
int xhs(vector<int> x)
{
int l=x.size();
vector<int> a,b,c;map<int,int> mp;
a.reserve(l*(l-1)/2),b.reserve(l*(l-1)/2);
for(int i=0;i<l;i++)for(int j=i+1;j<l;j++)
a.emplace_back(x[i]),b.emplace_back(x[j]);
c=ask(a,b);for(int i:c)mp[i]++;
for(auto [p,q]:mp)if(q==l)return p;
}
int richest(int N,int T,int S)
{
if(N==1000)
{
vector<int> a;a.resize(N);
iota(a.begin(),a.end(),0);
return xhs(a);
}
if(N==1000000)
{
vector<int> a;a.resize(N);
iota(a.begin(),a.end(),0);
int n=N;
for(int r=0;r<8;r++)
{
vector<int> b(n/x[r]),c(n/x[r]+1),t;
t.reserve(x[r]);
for(int i=0;i<x[r]-n%x[r];i++)
{
for(int j=0;j<n/x[r];j++)
b[j]=a[n/x[r]*i+j];
t.emplace_back(xhs(b));
}
for(int i=0;i<n%x[r];i++)
{
for(int j=0;j<n/x[r]+1;j++)
c[j]=a[(x[r]-n%x[r])*(n/x[r])+(n/x[r]+1)*i+j];
t.emplace_back(xhs(c));
}
a=t,n=x[r];
}
return a[0];
}
}
详细
Pretests
Pretest #1:
score: 0
Runtime Error
input:
1000 1 499500 957319859
output:
Unauthorized output
result:
Pretest #2:
score: 0
Runtime Error
input:
1000000 20 2000000 29091473
output:
Unauthorized output
result:
Final Tests
Test #1:
score: 0
Runtime Error
input:
1000 1 499500 957319857
output:
Unauthorized output
result:
Test #2:
score: 0
Runtime Error
input:
1000000 20 2000000 29091471
output:
Unauthorized output