QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#559867#9237. Messageyyyyxh#0 216ms4152kbC++232.3kb2024-09-12 10:03:182024-09-12 10:03:19

Judging History

你现在查看的是最新测评结果

  • [2024-09-12 10:03:19]
  • 评测
  • 测评结果:0
  • 用时:216ms
  • 内存:4152kb
  • [2024-09-12 10:03:18]
  • 提交

answer

#include "message.h"
#include <cstdio>
#include <algorithm>
using namespace std;
typedef vector<bool> vb;
namespace GO{
	int c[31][16];
	int encode(int cur){
		int res=0;
		for(int x=29;~x;--x)
			if(cur>>x&1) res+=c[x][16-__builtin_popcount(cur>>x)];
		return res;
	}
	int decode(int cur){
		int res=0;
		for(int x=29;~x;--x){
			int val=c[x][15-__builtin_popcount(res>>x)];
			if(cur>=val) cur-=val,res|=(1<<x);
		}
		return res;
	}
	void init(){
		for(int i=0;i<=30;++i){
			c[i][0]=1;
			for(int j=1;j<=15&&j<=i;++j) c[i][j]=c[i-1][j]+c[i-1][j-1];
		}
	}
}
void send_message(vb M,vb C){
	GO::init();
	int fir=0;
	for(int i=0;i<31;++i) if(!C[i]){fir=i;break;}
	if(fir==15){
		vb R(31);
		int p=15;
		auto add=[&](bool x)->void{
			R[p++]=x;
			if(p==31) send_packet(R),p=15;
		};
		for(int i=M.size();i<1024;++i) add(0);
		add(1);for(bool x:M) add(x);
	}
	else{
		int k=__lg(15^fir);
		for(int i=0;i<k;++i) send_packet(vb(31,fir>>i&1));
		int p=0;
		vector<vb> R(66,vb(31));
		int cur=0;
		for(int i=1;i<31;++i) if(!C[i]&&i!=fir) cur|=(1<<(i-1));
		cur=GO::encode(cur);
		auto add=[&](bool x)->void{
			R[p++][fir]=x;
			if(p==66){
				p=0;++fir;
				while(fir<31&&C[fir]) ++fir;
			}
		};
		for(int i=0;i<28;++i) add(cur>>i&1);
		for(int i=M.size();i<1024;++i) add(0);
		add(1);for(bool x:M) add(x);
		for(int i=0;i<66;++i) send_packet(R[i]);
	}
}
vb receive_message(vector<vb> R){
	GO::init();
	if(R.size()==65lu){
		int p=15,pp=0;
		auto qry=[&]()->bool{
			bool val=R[pp][p++];
			if(p==31) p=15,++pp;
			return val;
		};
		int len=1024;
		while(!qry()) --len;
		vb res(len);
		for(int i=0;i<len;++i) res[i]=qry();
		return res;
	}
	else{
		int k=R.size()-66;
		vb C(31);
		int fir=0;
		for(int i=k+1;i<4;++i) fir|=(1<<i);
		for(int i=0;i<k;++i){
			int cnt=0;
			for(int x:R[i]) if(x) ++cnt;
			if(cnt>15) fir|=(1<<i);
		}
		C[fir]=1;
		int p=k;
		auto qry=[&]()->bool{
			bool val=R[p++][fir];
			if(p==k+66){
				p=k;++fir;
				while(!C[fir]) ++fir;
			}
			return val;
		};
		int cur=0;
		for(int i=0;i<28;++i) if(qry()) cur|=(1<<i);
		cur=GO::decode(cur);
		for(int i=0;i<30;++i) if(cur>>i&1) C[i+1]=1;
		int len=1024;
		while(!qry()) --len;
		vb res(len);
		for(int i=0;i<len;++i) res[i]=qry();
		return res;
	}
}

详细

Subtask #1:

score: 0
Instance #1 Runtime Error

Test #1:

score: 8.574
Acceptable Answer
time: 162ms
memory: 4084kb

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: 187ms
memory: 3872kb

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: 196ms
memory: 3844kb

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: 216ms
memory: 4136kb

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: 160ms
memory: 4072kb

Manager to Aisha


Aisha to Manager


Manager to Basma


Basma to Manager


Manager to Checker

0.8574

result:

points 0.8574

Test #6:

score: 0
Instance #1 Runtime Error

Manager to Aisha


Aisha to Manager


Manager to Basma


Basma to Manager


Manager to Checker

0
ing with message 'manual RTE, cant read int from grader'
Quitting with result code 1

result:


Subtask #2:

score: 0
Instance #1 Runtime Error

Test #8:

score: 77.166
Acceptable Answer
time: 144ms
memory: 4052kb

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: 168ms
memory: 4144kb

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: 163ms
memory: 4152kb

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: 172ms
memory: 4068kb

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: 190ms
memory: 3808kb

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: 161ms
memory: 3880kb

Manager to Aisha


Aisha to Manager


Manager to Basma


Basma to Manager


Manager to Checker

0.8574

result:

points 0.8574

Test #14:

score: 0
Instance #1 Runtime Error

Manager to Aisha


Aisha to Manager


Manager to Basma


Basma to Manager


Manager to Checker

0
ing with message 'manual RTE, cant read int from grader'
Quitting with result code 1

result: