QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#554350 | #9237. Message | chenxinyang2006 | 85.74 | 202ms | 4124kb | C++20 | 3.4kb | 2024-09-09 10:34:31 | 2024-09-09 10:34:31 |
Judging History
answer
#include "message.h"
#include <bits/stdc++.h>
#define rep(i,j,k) for(int i=(j);i<=(k);i++)
#define per(i,j,k) for(int i=(j);i>=(k);i--)
#define uint unsigned int
#define ll long long
#define ull unsigned long long
#define db double
#define ldb long double
#define pii pair<int,int>
#define pll pair<ll,ll>
#define mkp make_pair
#define eb emplace_back
#define SZ(S) (int)S.size()
//#define mod 998244353
//#define mod 1000000007
#define inf 0x3f3f3f3f
#define linf 0x3f3f3f3f3f3f3f3f
using namespace std;
template <class T>
void chkmax(T &x,T y){
if(x < y) x = y;
}
template <class T>
void chkmin(T &x,T y){
if(x > y) x = y;
}
inline int popcnt(int x){
return __builtin_popcount(x);
}
inline int ctz(int x){
return __builtin_ctz(x);
}
bool fil(vector <bool> &M,int &pos){
if(pos < SZ(M)){
pos++;
return M[pos - 1];
}else if(pos == SZ(M)){
pos++;
return false;
}else{
pos++;
return true;
}
}
void send_message(vector<bool> M, vector<bool> C) {
vector <bool> A(31);
int l = 0,r = 30,m,ssum,pos = 0;
rep(p,0,4){
if(l == r){
rep(k,0,30) if(!C[k]) A[k] = fil(M,pos);
}else{
rep(k,0,l - 1) if(!C[k]) A[k] = fil(M,pos);
rep(k,r + 1,30) if(!C[k]) A[k] = fil(M,pos);
m = (l + r) >> 1;
ssum = 0;
rep(i,l,m){
if(C[i]) ssum--;
else ssum++;
}
if(ssum > 0){
rep(k,l,r) A[k] = 1;
r = m;
}else{
ssum = 0;
rep(i,m+1,r){
if(C[i]) ssum--;
else ssum++;
}
assert(ssum > 0);
rep(k,l,r) A[k] = 0;
l = m + 1;
}
}
send_packet(A);
// cerr << l << " " << r << endl;
}
rep(i,0,63){
rep(k,0,30){
if(C[k]) continue;
if(k == l && i <= 30){
A[k] = C[i];
}else{
A[k] = fil(M,pos);
}
}
send_packet(A);
}
}
vector<bool> receive_message(vector<vector<bool>> R) {
int c0,c1;
int l = 0,r = 30,m;
int pl[5],pr[5];
rep(p,0,4){
pl[p] = l;pr[p] = r;
if(l == r) continue;
c0 = c1 = 0;
rep(k,l,r){
if(!R[p][k]) c0++;
else c1++;
}
m = (l + r) >> 1;
// cerr << l << " " << r << endl;
if(c0 > c1) l = m + 1;
else r = m;
}
assert(l == r);
// cerr << l << endl;
vector <bool> C(31);
rep(p,0,30) C[p] = R[p + 5][l];
vector <bool> ans;
rep(p,0,4){
if(pl[p] < pr[p]){
rep(i,0,pl[p] - 1) if(!C[i]) ans.eb(R[p][i]);
rep(i,pr[p] + 1,30) if(!C[i]) ans.eb(R[p][i]);
}else{
rep(i,0,30) if(!C[i]) ans.eb(R[p][i]);
}
}
rep(i,0,63){
rep(k,0,30){
if(C[k]) continue;
if(k == l && i <= 30) continue;
ans.eb(R[5 + i][k]);
}
}
// cerr << "ok\n";
while(!ans.empty() && ans.back() == true) ans.pop_back();
assert(!ans.empty());
ans.pop_back();
return ans;
}
/*
g++ message.cpp grader.cpp -o grader.exe -Wall -Wshadow -O2 -std=c++14
*/
详细
Subtask #1:
score: 8.574
Acceptable Answer
Test #1:
score: 8.574
Acceptable Answer
time: 158ms
memory: 3756kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #2:
score: 8.574
Acceptable Answer
time: 178ms
memory: 3748kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #3:
score: 8.574
Acceptable Answer
time: 176ms
memory: 4060kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #4:
score: 8.574
Acceptable Answer
time: 185ms
memory: 4052kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #5:
score: 8.574
Acceptable Answer
time: 136ms
memory: 3864kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #6:
score: 8.574
Acceptable Answer
time: 83ms
memory: 4124kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #7:
score: 8.574
Acceptable Answer
time: 108ms
memory: 3816kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Subtask #2:
score: 77.166
Acceptable Answer
Test #8:
score: 77.166
Acceptable Answer
time: 160ms
memory: 4056kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #9:
score: 77.166
Acceptable Answer
time: 193ms
memory: 3812kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #10:
score: 77.166
Acceptable Answer
time: 123ms
memory: 3812kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #11:
score: 77.166
Acceptable Answer
time: 183ms
memory: 4124kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #12:
score: 77.166
Acceptable Answer
time: 139ms
memory: 3824kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #13:
score: 77.166
Acceptable Answer
time: 135ms
memory: 4060kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #14:
score: 77.166
Acceptable Answer
time: 81ms
memory: 4024kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #15:
score: 77.166
Acceptable Answer
time: 111ms
memory: 3856kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #16:
score: 77.166
Acceptable Answer
time: 108ms
memory: 4012kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #17:
score: 77.166
Acceptable Answer
time: 155ms
memory: 3760kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #18:
score: 77.166
Acceptable Answer
time: 128ms
memory: 3820kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #19:
score: 77.166
Acceptable Answer
time: 156ms
memory: 3792kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #20:
score: 77.166
Acceptable Answer
time: 164ms
memory: 4048kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #21:
score: 77.166
Acceptable Answer
time: 198ms
memory: 3804kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #22:
score: 77.166
Acceptable Answer
time: 168ms
memory: 4048kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #23:
score: 77.166
Acceptable Answer
time: 187ms
memory: 3816kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #24:
score: 77.166
Acceptable Answer
time: 200ms
memory: 3884kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #25:
score: 77.166
Acceptable Answer
time: 202ms
memory: 4060kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #26:
score: 77.166
Acceptable Answer
time: 158ms
memory: 3760kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574
Test #27:
score: 77.166
Acceptable Answer
time: 184ms
memory: 3812kb
Manager to Aisha
Aisha to Manager
Manager to Basma
Basma to Manager
Manager to Checker
0.8574
result:
points 0.8574