QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#555917#9237. Messagezhouhuanyi#Compile Error//C++142.7kb2024-09-10 12:29:572024-09-10 12:29:58

Judging History

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

  • [2024-09-10 12:29:58]
  • 评测
  • [2024-09-10 12:29:57]
  • 提交

answer

#include "message.h"
#include<iostream>
#include<cstdio>
#include<cstdlib>
#define N 32
using namespace std;
const __int128 mod=((__int128)(1)<<69)-19;
int r[32],tong[N+1],length;
bool used[32],delta[1025],nprime[N+1];
unsigned long long seed;
bool get_rand()
{
	seed^=(seed<<7);
	seed^=(seed<<13);
	seed^=(seed>>19);
	return seed&1;
}
void send_message(std::vector<bool> M, std::vector<bool> C)
{
	int ps=-1,rst=0,rst2=0;
	vector<bool>p;
	seed=998244353;
	for (int i=0;i<=1024;++i) delta[i]=0;
	for (int i=0;i<M.size();++i) delta[i]=M[i];
	delta[M.size()]=1,length=0;
	for (int i=1;i<=N;++i) nprime[i]=0;
	for (int i=2;i<=N;++i)
		if (!nprime[i])
		{
			for (int j=(i<<1);j<=N;j+=i) nprime[j]=1;
		}
	for (int i=N;i>=2;--i)
		if (!nprime[i])
		{
			for (int j=1;j<=4;++j)
				if (length+1<=31)
					tong[++length]=i;
		}
	for (int i=0;i<=15;++i)
		if (!C[i])
			rst|=(1<<i);
	for (int i=16;i<=30;++i)
		if (!C[i])
			rst2|=(1<<(i-16));
	for (int i=1;i<=6;++i)
	{
		p.clear();
		for (int j=0;j<=30;++j) p.push_back(((rst%tong[j+1])>>(i-1))&1);
		send_packet(p);
	}
	for (int i=1;i<=6;++i)
	{
		p.clear();
		for (int j=0;j<=30;++j) p.push_back(((rst2%tong[j+1])>>(i-1))&1);
		send_packet(p);
	}
	for (int i=1;i<=66;++i)
	{
		p.clear();
		for (int j=0;j<=30;++j)
		{
			if (C[j]) p.push_back(get_rand());
			else if (ps+1<=1024) p.push_back(delta[++ps]);
			else p.push_back(get_rand());
		}
		send_packet(p);
	}
	return;
}
std::vector<bool> receive_message(std::vector<std::vector<bool>> R)
{
	int ps=-1,rst=0,rst2=0,cnt;
	vector<bool>p;
	seed=998244353,length=0;
	for (int i=1;i<=N;++i) nprime[i]=0;
	for (int i=2;i<=N;++i)
		if (!nprime[i])
		{
			for (int j=(i<<1);j<=N;j+=i) nprime[j]=1;
		}
	for (int i=N;i>=2;--i)
		if (!nprime[i])
		{
			for (int j=1;j<=4;++j)
				if (length+1<=31)
					tong[++length]=i;
		}
	for (int i=0;i<=1024;++i) delta[i]=0;
	for (int i=1;i<=31;++i) r[i]=0;
	for (int i=1;i<=6;++i)
		for (int j=0;j<=30;++j)
			if (R[i-1][j])
				r[j+1]|=(1<<(i-1));
	for (int i=0;i<(1<<16);++i)
	{
		cnt=0;
		for (int j=1;j<=31;++j) cnt+=(i%tong[j]==r[j]);
		if (cnt>=16) rst=i;
	}
	for (int i=1;i<=31;++i) r[i]=0;
	for (int i=1;i<=6;++i)
		for (int j=0;j<=30;++j)
			if (R[i+5][j])
				r[j+1]|=(1<<(i-1));
	for (int i=0;i<(1<<15);++i)
	{
		cnt=0;
		for (int j=1;j<=31;++j) cnt+=(i%tong[j]==r[j]);
		if (cnt>=16) rst2=i;
	}
	for (int i=0;i<=15;++i) used[i]=(rst>>i)&1;
	for (int i=16;i<=30;++i) used[i]=(rst2>>(i-16))&1;
	for (int i=1;i<=66;++i)
		for (int j=0;j<=30;++j)
			if (used[j]&&ps+1<=1024)
				delta[++ps]=R[i+11][j];
	for (int i=ps;i>=0;--i)
		if (delta[i])
		{
			for (int j=0;j<=i-1;++j) p.push_back(delta[j]);
			break;
		}
	return p;
}

详细

stub.cpp: In function ‘int {anonymous}::sz(const C&)’:
stub.cpp:27:52: error: ‘size’ is not a member of ‘std’; did you mean ‘size_t’?
   27 | template<class C> int sz(const C& c) { return std::size(c); }
      |                                                    ^~~~
      |                                                    size_t
stub.cpp: In function ‘void {anonymous}::write_int_array(const int*, int)’:
stub.cpp:70:13: warning: init-statement in selection statements only available with ‘-std=c++17’ or ‘-std=gnu++17’
   70 |         if (int ret = fwrite(arr, sizeof(int), len, fout); len != ret) {
      |             ^~~
stub.cpp: In function ‘void {anonymous}::read_int_array(int*, int)’:
stub.cpp:105:13: warning: init-statement in selection statements only available with ‘-std=c++17’ or ‘-std=gnu++17’
  105 |         if (int ret = fread(arr, sizeof(int), len, fin); len != ret) {
      |             ^~~