QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#559720#9237. MessagezhouhuanyiCompile Error//C++143.9kb2024-09-12 08:41:412024-09-12 08:41:41

Judging History

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

  • [2024-09-12 08:41:41]
  • 评测
  • [2024-09-12 08:41:41]
  • 提交

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],sp[31],cnt[1<<16],rd[30][32],tong[N+1],length;
bool used[32],delta[1025],nprime[N+1],vis[1<<16];
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=1;i<=10;++i)
		for (int j=0;j<=30;++j)
			rd[i][j]=get_rand();
	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<=30;++i) sp[i]=i;
	for (int i=1;i<30;++i) swap(sp[i],sp[seed%i]);
	for (int i=0;i<=15;++i)
		if (!C[sp[i]])
			rst|=(1<<i);
	for (int i=16;i<=30;++i)
		if (!C[sp[i]])
			rst2|=(1<<(i-16));
	for (int i=1;i<=5;++i)
	{
		p.clear();
		for (int j=0;j<=30;++j)
		{
			if (!C[j]) p.push_back((((rst%tong[j+1])>>(i-1))&1)^rd[i][j]);
			else p.push_back(get_rand());
		}
		send_packet(p);
	}
	for (int i=1;i<=5;++i)
	{
		p.clear();
		for (int j=0;j<=30;++j)
		{
			if (!C[j]) p.push_back((((rst2%tong[j+1])>>(i-1))&1)^rd[i+5][j]);
			else p.push_back(get_rand());
		}
		send_packet(p);
	}
	for (int i=1;i<=65;++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=-1,rst2=-1;
	vector<bool>p;
	vector<int>A;
	vector<int>B;
	seed=998244353;
	for (int i=1;i<=10;++i)
		for (int j=0;j<=30;++j)
			rd[i][j]=get_rand();
	for (int i=0;i<=1024;++i) delta[i]=0;
	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<=5;++i)
		for (int j=0;j<=30;++j)
			if (R[i+4][j]^rd[i+5][j])
				r[j+1]|=(1<<(i-1));
	for (int i=0;i<(1<<16);++i) cnt[i]=0;
	for (int i=1;i<=31;++i) r[i]=0;
	for (int i=1;i<=5;++i)
		for (int j=0;j<=30;++j)
			if (R[i-1][j]^rd[i][j])
				r[j+1]|=(1<<(i-1));
	for (int i=1;i<=31;++i)
		for (int j=r[i];j<(1<<16);j+=tong[i])
			cnt[j]++;
	for (int i=0;i<(1<<16);++i)
		if (cnt[i]>=16)
			A.push_back(i);
	for (int i=0;i<(1<<15);++i) cnt[i]=0;
	for (int i=1;i<=31;++i) r[i]=0;
	for (int i=1;i<=5;++i)
		for (int j=0;j<=30;++j)
			if (R[i+4][j]^rd[i+5][j])
				r[j+1]|=(1<<(i-1));
	for (int i=1;i<=31;++i)
		for (int j=r[i];j<(1<<15);j+=tong[i])
			cnt[j]++;
	for (int i=0;i<(1<<15);++i)
		if (cnt[i]>=16)
			B.push_back(i);
	for (int i=0;i<A.size();++i)
		for (int j=0;j<B.size();++j)
			if (__builtin_popcount(A[i])+__builtin_popcount(B[j])==16)
				rst=A[i],rst2=B[j];
	for (int i=1;i<=31;++i) r[i]=0;
	for (int i=1;i<=5;++i)
		for (int j=0;j<=30;++j)
			if (R[i+4][j]^rd[i+5][j])
				r[j+1]|=(1<<(i-1));
	for (int i=0;i<=30;++i) sp[i]=i;
	for (int i=1;i<30;++i) swap(sp[i],sp[seed%i]);
	for (int i=0;i<=15;++i) used[sp[i]]=(rst>>i)&1;
	for (int i=16;i<=30;++i) used[sp[i]]=(rst2>>(i-16))&1;
	for (int i=1;i<=65;++i)
		for (int j=0;j<=30;++j)
			if (used[j]&&ps+1<=1024)
				delta[++ps]=R[i+9][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) {
      |             ^~~