QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#528691 | #9162. COVID tests | makrav# | 36.85 | 374ms | 4076kb | C++20 | 4.1kb | 2024-08-23 19:51:45 | 2024-08-23 19:51:46 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define all(x) (x).begin(), (x).end()
#define sz(x) (int)(x).size()
mt19937 rnd(time(NULL));
double rand_d() {
return (double)(rnd() % RAND_MAX) / RAND_MAX;
}
void rsh(vector<int> &x) {
for (int i = 1; i < x.size(); i++) {
swap(x[i], x[rnd() % (i + 1)]);
}
}
vector<int> fs = {4530, 15330, 28470, 57450, 73890, 109860, 147090, 191730, 219420};
void solve(int tc) {
int n, t;
double p; cin >> n >> p >> t;
int qtot = 0;
int sm =0;
for (int i = 0; i < t; i++) {
int cur = 0;
for (int j = 0; j < n; j++) cur += (rand_d() <= p);
sm= max(sm,cur);
}
int exp = sm+3;
for (int lol = 0; lol < t; lol++) {
vector<int> res(n);
int SS=0;
for (int i = 0; i < n; i++) {
res[i] = rand_d() <= p;
SS+=res[i];
}
int curtot = 0;
auto ask = [&](string s) -> bool {
qtot++;
curtot++;
#ifdef LOCAL
int ans = 0;
for (int i = 0; i < n; i++) {
if (s[i] == '1') ans |= res[i];
}
return ans;
#else
cout << "Q " << s << endl;
char c; cin >> c;
return (c == 'P');
#endif
};
auto check = [&](string ans) {
#ifdef LOCAL
for (int i = 0; i < n; i++) {
if (ans[i] - '0' != res[i]) return false;
}
return true;
#else
cout << "A " << ans << endl;
char c; cin >> c;
return (c == 'C');
#endif
};
string ans, req;
for (int i = 0; i < n; i++) {
ans += '0';
req += '0';
}
auto solve = [&](int l, int r, auto&&solve) -> void {
for (int i = l; i < r; i++) req[i] = '1';
bool rs = ask(req);
for (int i = l; i < r; i++) req[i] = '0';
if (!rs) return;
if (l + 1 == r) {
ans[l] = '1';
return;
}
int m = (l + r) / 2;
solve(l, m, solve);
solve(m, r, solve);
};
// while (sz(poss) > 2*exp) {
// double newp = (double) exp / (double) sz(poss);
// int siz = 1;
// double P=1-newp;
// while(siz<=sz(poss)-exp&&P>=0.05){
// siz++;
// P*=(1-newp);
// }
// if(siz>sz(poss)-exp)siz=sz(poss)-exp;
// siz=4;
// int ci = 0;
// while (true) {
// ci++;
// rsh(poss);
// string S;
// for (int j = 0; j < n; j++) S += '0';
// for (int i = 0; i < siz; i++) S[poss[i]] = '1';
// if (!ask(S)) {
// reverse(all(poss));
// for (int j = 0; j < siz; j++) poss.pop_back();
// break;
// }
// }
// }
// string answ;
// for (int i = 0; i < n; i++) answ += '0';
// for (int j = 0; j < sz(poss); j++) {
// string S;
// for (int i = 0; i < n; i++) S += '0';
// S[poss[j]] = '1';
// if (ask(S)) answ[poss[j]] = '1';
// }
solve(0, n, solve);
assert(check(ans));
}
#ifdef LOCAL
double pts = 0;
if (qtot <= fs[tc]) {
pts = 90;
} else if (qtot <= 10 * fs[tc]) {
pts = 90 * (double)fs[tc] / (double)(fs[tc] + 4 * (qtot - fs[tc]));
}
cout << "gained " << pts << '\n';
#endif
}
signed main() {
int tt = 1;
#ifdef LOCAL
freopen("in.txt", "r", stdin);
freopen("out.txt", "w", stdout);
cin >> tt;
#endif
for (int i = 0; i < tt; i++) {
solve(i);
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Subtask #1:
score: 10
Accepted
Test #1:
score: 10
Accepted
time: 0ms
memory: 4036kb
input:
1000 0.789673 1 P P P P P P P P P P P N P P P P P P P P P P P P N P P P P P N P P N P P P P P P P P P P P P N P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P N P P P P P P P P N P P P P P P P P N P P N P P P P P P P P P N P P P P P P P P N P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #2:
score: 10
Accepted
time: 21ms
memory: 3792kb
input:
1000 0.686378 1 P P P P P P P P P N P P N P N P P N P P P N P P N P P P P N P N P P P P P P P P P N P P P P P P N P P P P P P P N P P N P P N P P P P P P P P N P N P P N P P P P P P P N P P P P P P P P P P P P P N P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #3:
score: 10
Accepted
time: 0ms
memory: 3848kb
input:
1000 0.873862 1 P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #4:
score: 10
Accepted
time: 8ms
memory: 3884kb
input:
1000 0.669578 1 P P P P P P P P P P P P N P P P P P P P P P P P N P P N P P P P P P N P P P P P P P P P P P P P P P N P P P P P P P P P N P P N P P P P P P N P P P P N P P P P P P N P P P N P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P N P P N P P P N P P P P P P P P N P P N P P P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #5:
score: 10
Accepted
time: 5ms
memory: 4008kb
input:
1000 0.907052 1 P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #6:
score: 10
Accepted
time: 0ms
memory: 3840kb
input:
1000 0.844418 1 P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P P P P P P N P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P N P P P P P P P P P N P P P P P P P P P N P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #7:
score: 10
Accepted
time: 16ms
memory: 4068kb
input:
1000 0.533576 1 P P P P P P P P P P P P P N P P P P P N P P P N P P N P P P P P P P N P P N P P N P P P P N P P P P P N P P N P P P P P N P P P P P P P N P P P N P P P P P P P P N P P P P P P P N P P P P P P P P P P P N P P P P P P P N N P P P P P N P N P P P N P P P P P P P N P P N P P P P P P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #8:
score: 10
Accepted
time: 4ms
memory: 3844kb
input:
1000 0.415944 1 P P P P P P P N P P P P N P N P P N P P N P P P P P N N P P P N N P N P N P P N P P P N P P P P P P P P P P N P N P P P N P N P P P P N P P P P P N P P P P P P N P P N P P P N N P P P P P N P N P P P N P P N P P P P N P N P P N P N P P P N P P N P P N P P P P P P P P P N P P N P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #9:
score: 10
Accepted
time: 0ms
memory: 3992kb
input:
1000 0.596017 1 P P P P P P P P P P P N P P P P N P N P P P N P P P P P P N P P N P P P P N P P P P P P N P P N P P P N P N P P N P P N P P P P N P P N P P P P P P N P P P P P P N P P P P P P N P P P P P N P P P P P P N P N P P P P P P P N P P P N N P P P P P P N P P N P P P P P P P N P P P P P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #10:
score: 10
Accepted
time: 6ms
memory: 3904kb
input:
1000 0.157686 1 P P P P P P P N P N P N P P N P P P N P P P P N P P N P P N P N P N P P N P P P P N N P P P P N P P P P P N P P N N P P P P N N N P P P N P N P P P N N P N P N P P P P N P P P N P P N P P P N N P P P P P P P P P N N P P P P P N P N P N P P P N P P N N P P P P P N N P N P P N P N P N ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #11:
score: 10
Accepted
time: 0ms
memory: 3908kb
input:
1000 0.380215 1 P P P P P P P P N P P P N N P P P P N P N P P N P N P P P P P P N P P N P N P P P P P P P N P P P P N P N P P P P N P P P N N P P P P P P P P N P P P P N P P P N N N P P P P P N P P P N P P P P P N P P N P N P P P N P N P P P N P N P P P P N N P P N P N P P P P N P P P P P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #12:
score: 10
Accepted
time: 4ms
memory: 4064kb
input:
1000 0.432565 1 P P P P P P P P P P P N P P N P P N P P N P P P P P P N P P P P N P P P N P P P P P P N P P P N P P P P N P P P P P P P P N P P P P P N N P P N P P P P P P P P P N P P N P P N P P P P P N P P P N P P N P P P P P P P N P P P N P P P N P P P N P N P P P N N P P P P P N P P N P N P P N ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #13:
score: 10
Accepted
time: 4ms
memory: 3836kb
input:
1000 0.509199 1 P P P P P P P P P P P P N P P P N N P P P P P N P N P N P P P P N P P P P P N P P P N P P P P P P P P P P P N P N P P P P P N P P P P P N P P P P P P P P P P P P P P P P P P N P P P P P P P P N P P N P P N P P P P P N P P N P P P N P N P P P P P P N P P N P P P N N P P N P P P P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #14:
score: 10
Accepted
time: 4ms
memory: 3876kb
input:
1000 0.381646 1 P P P P P P P P N P P P N N P P P N P P P P N P P P P N P N P P N P P N P P P P N P P N P N P P P N P P P P N P P N P P P N P P P P N P N P N P P N P P P P N N P P N P P P P P P P P P N P P P P P N P P P P P P P N P P N P P P P P N P P P N P N P P N P P P P P P N P P P N P P P P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #15:
score: 10
Accepted
time: 3ms
memory: 3832kb
input:
1000 0.42815 1 P P P P P P P P P N P P P P P N P P N P P P P P P N P P P N P N P P P P N P P P P P P N N P P P N P P P P P N P N P P P P P P P N P P N P P N P P N P P P N P P P P P N P N P P P P N P P N P P N P N P N P P P P P N P P N P P P P P N P P P P P P P P N P N P P P P P P P P N P P P P P P N...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #16:
score: 10
Accepted
time: 0ms
memory: 3768kb
input:
1000 1 1 P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P P...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Test #17:
score: 10
Accepted
time: 1ms
memory: 4060kb
input:
1000 0 1 N C
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 1.0 1.0 translate:success
Subtask #2:
score: 26.85
Acceptable Answer
Test #18:
score: 52.47
Acceptable Answer
time: 20ms
memory: 3844kb
input:
1000 0.001 300 N C P N P P N P N P P P P N P N P P N N N N N C P N P N P P N P P N P P N P P N P N N P N P N P P N P N P N P P P N P N P P N P P N N N N C N C N C P P N P P N P P N P N P N P P P N N N N N C P N P N P P P P N P N P N P N P N P N N N C N C N C P P N P P P P P N P P N P N P N N N N N N...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.5830 0.583 Output is correct (P=0.001, F=15.1, Q=17.8) -> 52.47 points
Test #19:
score: 28.98
Acceptable Answer
time: 32ms
memory: 4064kb
input:
1000 0.005256 300 P P P P N P N P P P P P P N N N P P N P P N N N N P N P N P P P P N P N P N P N N N P N P P P N P P P P P N N N N N P N P P N P P N P P P N N N N C P N P P P N P N P P N P N P P P N N N N P P N P N P P N P P N P N P N N P P N P P P P N P N P N N N N C P N P N P N P P N P P N P N P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.3220 0.322 Output is correct (P=0.005256, F=51.1, Q=78.0) -> 28.98 points
Test #20:
score: 27.05
Acceptable Answer
time: 34ms
memory: 4076kb
input:
1000 0.011546 300 P P P P P P N P P P P N P N N P P N P P N N N N P N P N P N P P N P P N P N N P P P N P N P P N P N P N P P P P N P P N P N P P N P N P P P P N N N P P P P P P N N N N N N P N P P P N P N P N P N P P N P N P N P P N P P N P P N N N P N P P P P P P N N N N P P P P P P N N N N N C P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.30055555560 0.3005555556 Output is correct (P=0.011546, F=94.9, Q=150.1) -> 27.05 points
Test #21:
score: 26.85
Acceptable Answer
time: 128ms
memory: 3872kb
input:
1000 0.028545 300 P P P P P P P P P P N N N N N P P N P P P N P P N N N N P P P P N P P N P N P P N P N P N N P P N P N P P P P N N P P P N N P N P P N P N P P N N P P N P P N P N P P P N P N N P P N P N P N P P N P N P N P P N P N P P P P N P P N P N P N N P P P P N P P P N P P N P P N P N P N P N ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.29833333330 0.2983333333 Output is correct (P=0.028545, F=191.5, Q=304.1) -> 26.85 points
Test #22:
score: 27.24
Acceptable Answer
time: 185ms
memory: 3844kb
input:
1000 0.039856 300 P P P P P P P N P P N P P N N P N P N P N P P N P P P P N P N P N N N N P P N P P P P N P P N N N P N P N P P P N P P N P P P P N P P N P N P N P P P N N P P N P P P N N P P P P N N N N P P P P P P P P N N N P P P P N P N N N P P P P N P N P N N P P N P P P N N N P P P N P N P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.30266666670 0.3026666667 Output is correct (P=0.039856, F=246.3, Q=388.2) -> 27.24 points
Test #23:
score: 27.96
Acceptable Answer
time: 233ms
memory: 4068kb
input:
1000 0.068648 300 P P P P P P P N P N P N P N P P P P N P N P P N P N P P P P P N N N P P P N P P N P P P N P P P P N N N P P P P N P N P N P P N N P P P N P N P N P P N P P N P N P N P N P P P P P P N N N N P N P P N P P N N P P P N P P P P N P N N N N P P N P N P P P N P N N P P P P N P P P P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.31066666670 0.3106666667 Output is correct (P=0.068648, F=366.2, Q=569.3) -> 27.96 points
Test #24:
score: 28.72
Acceptable Answer
time: 298ms
memory: 3832kb
input:
1000 0.104571 300 P P P P P P N P P N P N P P N N P P P N P P P N P P P N P N P N P P P N P N P P P P P N P N P P N P P P N P N N P P P P P N P N P P P P N N P P N P N P P P N P N P N P N P N P N P N P P P P N P P P P P N N N N P P P P N P P N N N P N P N P N P N P P P P P P N P P N P N P P N P P P ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.31911111110 0.3191111111 Output is correct (P=0.104571, F=490.3, Q=751.8) -> 28.72 points
Test #25:
score: 29.44
Acceptable Answer
time: 374ms
memory: 3840kb
input:
1000 0.158765 300 P P P P P P N P P P P N P N P N P N P N P P P P N P P P N N N P P P N P P P P N P P N N P N P N P P P N N P P N P P N P P N N P N P P N P P N N P P P P P P N P N P N P N P N P P N P N P N P P N P N P P P P P N P N P P N P N P P N P N N P P P P N P N P N P P P P P P N N P P P N P N ...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.32711111110 0.3271111111 Output is correct (P=0.158765, F=639.1, Q=967.7) -> 29.44 points
Test #26:
score: 29.18
Acceptable Answer
time: 344ms
memory: 4068kb
input:
1000 0.2 300 P P P P P P P P N P P N P N P P N P P N P P P N N P N P N P N P P N P P P P P P P N P N P N P P P P N P N P P P N P P N P P P N P P N P P P N N P P P P P N P N P N P P P P P P N P N P N N P P P N P P P P P P N N P P N P P N N P P P P P P N N P P P N N P P P P N N N P P N P N P P N P P P...
output:
Q 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
result:
points 0.32422222220 0.3242222222 Output is correct (P=0.2, F=731.4, Q=1112.6) -> 29.18 points