QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#492527 | #9156. 百万富翁 | wangziji | 100 ✓ | 2398ms | 128936kb | C++20 | 1.2kb | 2024-07-26 13:09:46 | 2024-07-26 13:09:47 |
Judging History
answer
#include "richest.h"
#include<bits/stdc++.h>
using namespace std;
int a[10]={1000000,500000,250000,125000,62500,20833,3472,183,1};
int col[1000005];
vector<int> v[1000005];
bitset<1000005> ok,vis;
int richest(int N, int T, int qwq) {
vector<int> S;
if(N==1000)
{
a[0]=1000;
a[1]=1;
}
for(int i=1;i<=N;i++) S.push_back(i-1);
for(int i=1;i<=(N==1000?1:8);i++)
{
int w=a[i-1]/a[i],C1=a[i-1]%a[i],C0=a[i]-C1;
int nw=0,C=0;
for(int i=0;i<=N;i++) v[i].clear();
for(int i=1;i<=C1;i++)
{
++C;
for(int j=0;j<=w;j++)
v[C].push_back(S[nw++]);
}
for(int i=1;i<=C0;i++)
{
++C;
for(int j=1;j<=w;j++)
v[C].push_back(S[nw++]);
}
vector<int> v1,v2;
set<int> ss;
vis.reset();
for(int i=1;i<=C;i++)
{
for(auto x:v[i])
{
for(auto y:v[i])
{
if(x==y) break;
v1.push_back(x),v2.push_back(y);
vis[x]=vis[y]=1;
}
}
}
vector<int> V=ask(v1,v2);
ok.reset();
for(int i=0;i<v1.size();i++)
{
ok[v1[i]+v2[i]-V[i]]=1;
}
S.clear();
for(int i=0;i<N;i++)
if(!ok[i]&&vis[i]) S.push_back(i);
// for(auto t:ss) S.push_back(t);
}
// cout << S.size() << "\n";
return S[0];
}
詳細信息
Pretests
Pretest #1:
score: 15
Accepted
time: 614ms
memory: 22496kb
input:
1000 1 499500 957319859
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Pretest #2:
score: 85
Accepted
time: 2391ms
memory: 114160kb
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: 610ms
memory: 23156kb
input:
1000 1 499500 957319857
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Test #2:
score: 85
Accepted
time: 2398ms
memory: 128936kb
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