QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#509732 | #9156. 百万富翁 | Arapak# | 23.99997 | 3543ms | 125460kb | C++20 | 2.1kb | 2024-08-08 18:01:36 | 2024-08-08 18:01:36 |
Judging History
answer
#include "bits/stdc++.h"
#include "richest.h"
using namespace std;
#define rep(i,a,b) for(int i=(a);i<(b);++i)
#define all(x) begin(x), end(x)
#define sz(x) (int)x.size()
typedef long long ll;
typedef vector<int> vi;
typedef pair<int,int> pii;
#ifdef DEBUG
auto& operator<<(auto& os, const pair<auto,auto> &p) {
return os<<"("<<p.first<<", "<<p.second<<")";
}
auto& operator<<(auto& os, const auto &v) {
os<<"{";
for(auto it=begin(v);it!=v.end();++it) {
if(it!=begin(v)) os<<", ";
os<<(*it);
}
return os<<"}";
}
void dbg_out(auto... x) {
((cerr<<' '<<x), ...) << endl;
}
#define dbg(x...) cerr<<"("<<#x<<"):", dbg_out(x);
#else
#define dbg(...)
#endif
int solve(vector<int> ind) {
dbg(ind);
int n = sz(ind);
vector<pii> q;
for(int i=0;i<n;i+=3) {
if(i+3<=n) {
q.emplace_back(i, i+1);
q.emplace_back(i, i+2);
q.emplace_back(i+1, i+2);
}
else if(i+2<=n)
q.emplace_back(i, i+1);
}
vi a, b;
for(auto [x, y] : q) {
a.push_back(ind[x]);
b.push_back(ind[y]);
}
dbg(a, b);
vi res = ask(a, b);
dbg(res);
vi new_ind;
for(int i=0;i<n;i+=3) {
if(i+3<=n) {
auto check = [&](const int index) {
int num = 0;
num += res[i] == ind[index];
num += res[i+1] == ind[index];
num += res[i+2] == ind[index];
return num == 2;
};
if(check(i)) new_ind.push_back(ind[i]);
else if(check(i+1)) new_ind.push_back(ind[i+1]);
else new_ind.push_back(ind[i+2]);
}
else if(i+2<=n)
new_ind.push_back(res[i]);
else
new_ind.push_back(ind[i]);
}
// for(auto &x : new_ind)
// x = ind[x];
dbg(new_ind);
if(sz(new_ind) == 1) return new_ind[0];
return solve(new_ind);
}
int richest(int N, int T, int S) {
if(T == 1) {
vi a, b;
rep(i,0,N) rep(j,i+1,N) {
a.push_back(i);
b.push_back(j);
}
auto res = ask(a, b);
sort(all(res));
int prev = -1;
int num = 0;
for(auto x : res) {
if(x == prev) {
num++;
if(num == N-1) return x;
}
else {
prev = x;
num = 1;
}
}
assert(false);
}
vi perm(N);
iota(all(perm), 0);
return solve(perm);
}
详细
Pretests
Pretest #1:
score: 15
Accepted
time: 746ms
memory: 25352kb
input:
1000 1 499500 957319859
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Pretest #2:
score: 8.99997
Acceptable Answer
time: 3543ms
memory: 124132kb
input:
1000000 20 2000000 29091473
output:
Partially correct Case 2, 9 / 85, maxt = 13, maxs = 1499997 7616820272462450011 0.105882 16926627793318235567
result:
points 0.105882 Partially correct Case 2, 9 / 85, maxt = 13, maxs = 1499997
Final Tests
Test #1:
score: 15
Accepted
time: 742ms
memory: 25372kb
input:
1000 1 499500 957319857
output:
Correct 7127326332295218295 1.000000 1331569654267968081
result:
points 1.0 Correct
Test #2:
score: 8.99997
Acceptable Answer
time: 3509ms
memory: 125460kb
input:
1000000 20 2000000 29091471
output:
Partially correct Case 2, 9 / 85, maxt = 13, maxs = 1499997 7616820272462450011 0.105882 16926627793318235567
result:
points 0.105882 Partially correct Case 2, 9 / 85, maxt = 13, maxs = 1499997