首页 > 其他分享 >[P7738][NOI2021] 量子通信

[P7738][NOI2021] 量子通信

时间:2023-05-27 21:33:53浏览次数:30  
标签:10 P7738 01 15 times NOI2021 le Bob 量子

[NOI2021] 量子通信

题目背景

由于评测性能差异,本题时限 +0.5s。

题目描述

小 Z 正在自学量子计算机相关知识,最近他在研究量子通信章节,并遇到了一个有趣的问题。在该问题中,Alice 和 Bob 正在进行量子通信,它们的通信语言是一个大小为 \(n\) 的字典 \(S\),在该字典中,每一个单词 \(s_i\)(\(1 \le i \le n\))都可以用一个 \(\boldsymbol{256}\) 位的 \(\boldsymbol{01}\) 来表示。在本题中 \(s_i\) 可以通过调用函数 gen 来生成,选手可以在题目目录下的 gen.cpp 中查看,该函数的参数 na1a2 将由输入数据给出。

Alice 和 Bob 接下来要进行 \(m\) 次通信,每次通信由 Alice 向 Bob 传输恰好一个字典中的单词。然而,两人使用的通信信道并不可靠,会受到噪音的干扰。更具体地,对于第 \(i\) 次传输,记 Alice 传输的原单词为 \(x_i\),该 \(01\) 串会受噪音干扰而翻转最多 \(\boldsymbol{k_i}\) 。换句话说,记 Bob 这次收到的 \(01\) 串为 \(y_i\),它与 \(x_i\) 相比,可能有最多 \(k_i\) 位是不同的,并且 \(y_i\) 可能不在字典 \(S\) 中出现。

与此同时,Bob 得知坏人 Eve 也潜入了两人的通信信道,并准备干扰两人的通信。他的干扰方式是将 Bob 收到的 \(01\) 串变为任意的 \(256\) 位 \(01\) 串,并且这个串可能不在字典 \(S\) 中出现。Eve 非常狡猾,他不一定会对每次通信都进行干扰。

现在 Bob 找来了你帮忙,对于接下来的每次通信,你需要根据 Bob 最终收到的 \(01\) 串以及这次通信的噪音干扰阈值 \(k_i\)(\(0 \le k_i \le 15\)),判断这次通信是否有可能没有受到 Eve 的干扰(即 Bob 收到的 \(01\) 串可以由字典中的某个单词翻转至多 \(k_i\) 位后得到)。本次通信如果有可能没受到 Eve 干扰,请你输出 \(1\),否则输出 \(0\)。Bob 很信任你的能力,所以你需要在线地回答结果,具体要求见输入格式

为了降低读入用时, Bob 收到的串将用长度为 \(\boldsymbol{64}\) \(\boldsymbol{16}\) 进制串给出,\(16\) 进制串中包含数字字符 \(\texttt{0} \sim \texttt{9}\) 与大写英文字母 \(\texttt{A} \sim \texttt{F}\),其中字符 \(\texttt{A} \sim \texttt{F}\) 依次表示数值 \(10 \sim 15\)。

\(16\) 进制串可以逐位转化为 \(01\) 串,例如:5 对应 0101A 对应 1010C 对应 1100

输入格式

输入数据第一行包含四个非负整数 \(n, m, a_1, a_2\),分别表示字典大小,通信次数,以及 gen 函数中参数 a1a2 的初始值。

选手需要在自己的程序中调用题目描述中提到的 gen 函数生成单词表,选手可以复制并使用 gen.cpp 中的代码,程序中的布尔数组 s[N+1][256] 即为所有的单词。

接下来 \(m\) 行,每行包含一个长度为 \(64\) 的 \(16\) 进制串和一个非负整数 \(k_i\),分别表示第 \(i\) 次通信 Bob 最终收到的 \(01\) 串和噪音干扰阈值。

为了强制选手在线地回答询问,选手根据 \(16\) 进制串还原出 \(256\) 位 \(01\) 串后,将 \(01\) 串每一位异或上 \({\mathit{lastans}}\) 才能得到这次通信中 Bob 收到的真实 \(01\) 串,其中 \({\mathit{lastans}} \in \{ 0, 1 \}\) 表示上一次询问的答案,第一个询问前 \({\mathit{lastans}}\) 初始值为 0。

注意:使用 scanfprintf 函数读入或输出 unsigned long long 类型变量时,对应的占位符为 llu

输出格式

输出共 \(m\) 行,每行一个整数 \(0\) 或 \(1\) 表示当前询问的答案。

样例 #1

样例输入 #1

见附件中的 qi/qi1.in

样例输出 #1

见附件中的 qi/qi1.ans

样例 #2

样例输入 #2

见附件中的 qi/qi2.in

样例输出 #2

见附件中的 qi/qi2.ans

样例 #3

样例输入 #3

见附件中的 qi/qi3.in

样例输出 #3

见附件中的 qi/qi3.ans

提示

【询问举例】

为了方便解释题意,我们使用了直接给出字典中单词、缩小单词长度为 \(4\)、允许离线地回答询问等方式,对简化的情况举例。

考虑字典大小为 \(n = 2\),单词有 10100111

对于询问 B = 1011 和 \(k_1 = 1\),回答应该是 \(1\),通过翻转 1010 的第 \(4\) 位(从高位到低位,下同)得到。

对于询问 1 = 0001 和 \(k_2 = 2\),回答应该是 \(1\),通过翻转 0111 的第 \(2\)、\(3\) 位得到。

对于询问 1 = 0001 和 \(k_3 = 1\),回答应该是 \(0\)。

  • 翻转 1010 至多 \(1\) 位可得 10100010111010001011
  • 翻转 0111 至多 \(1\) 位可得 01111111001101010110
  • 无法得到 1 = 0001,它必定是由 Eve 干扰得到的。

【数据范围】

对于所有测试点:\(1 \le n \le 4 \times {10}^5\),\(1 \le m \le 1.2 \times {10}^5\),\(0 \le k_i \le 15\),\(a_1\) 和 \(a_2\) 在 \([0, 2^{64} - 1]\) 之间均匀随机生成。

测试点编号 \(n =\) \(m =\) \(k_i \le\) 特殊性质
\(1\) \(10\) \(10\) \(2\)
\(2\) \(500\) \(500\) \(15\)
\(3\) \(1000\) \(1000\) \(0\)
\(4\) \(2000\) \(2000\) \(2\)
\(5\) \(5000\) \(5000\) \(15\)
\(6\) \(10^4\) \(10^4\) \(15\)
\(7\) \(2\times 10^4\) \(2\times 10^4\) \(15\)
\(8\) \(10^5\) \(10^5\) \(1\)
\(9\) \(4\times 10^5\) \(1.2\times 10^5\) \(1\)
\(10\) \(5\times 10^4\) \(5\times 10^4\) \(2\)
\(11\) \(7\times 10^4\) \(7\times 10^4\) \(3\)
\(12\) \(10^5\) \(10^5\) \(2\)
\(13\) \(3\times 10^4\) \(3\times 10^4\) \(5\)
\(14\) \(6\times 10^4\) \(6\times 10^4\) \(4\)
\(15\) \(1.2\times 10^5\) \(1.2\times 10^5\) \(5\)
\(16\) \(6\times 10^4\) \(6\times 10^4\) \(8\) 所有询问串随机生成
\(17\) \(1.2\times 10^5\) \(1.2\times 10^5\) \(12\) 所有询问串随机生成
\(18\) \(4\times 10^5\) \(10^5\) \(15\) 所有询问串随机生成
\(19\) \(3\times 10^4\) \(3\times 10^4\) \(7\)
\(20\) \(6\times 10^4\) \(6\times 10^4\) \(9\)
\(21\) \(9\times 10^4\) \(9\times 10^4\) \(11\)
\(22\) \(2\times 10^5\) \(1.2\times 10^5\) \(12\)
\(23\) \(4\times 10^5\) \(8\times 10^4\) \(15\)
\(24\) \(4\times 10^5\) \(10^5\) \(15\)
\(25\) \(4\times 10^5\) \(1.2\times 10^5\) \(15\)

如何迅速判断一个串是否符合要求?显然bitset

那么我们可以找到所有的有可能成为答案的串,一一判断

随机数据,如果是固定了整个串的某几位,那么期望情况下,可选的答案会少很多。

\(k\le15\),如果存在符合要求的串,那么这个串的大多数位置都是和给的串是一样的。但是仍然没有办法找到一些一定一样的串来减少位置。注意到 \(15<\sqrt{256}\),我们可以把整个询问串分成16个长度为16的串,根据抽屉原理,集合中一个满足要求的串,一定存在某一块串是和询问串串是相同的。那么串的集合中这一块串和询问串这一块相等的期望串数量有 \(\frac{n}{2^{16}}\) 个。我们回答一次询问的复杂度就是 \(\frac{n}{2^{16}}\times 16\times \frac{256}{\omega}\),可过。

#include <bits/stdc++.h>
using namespace std;
typedef unsigned long long ull;
const int N=4e5+1,M=2e5+1;
ull a1,a2;
char str[256];
bitset<256> s[N],p;
int lst,n,m,k;
ull myRand(ull &k1, ull &k2) {
    ull k3 = k1, k4 = k2;
    k1 = k4;
    k3 ^= (k3 << 23);
    k2 = k3 ^ k4 ^ (k3 >> 17) ^ (k4 >> 26);
    return k2 + k4;
}

void gen(int n, ull a1, ull a2) {
    for (int i = 1; i <= n; i++)
        for (int j = 0; j < 256; j++)
            s[i][j] = (myRand(a1, a2) & (1ull << 32)) ? 1 : 0;
}
vector<int>g[16][1<<16];
int main() {
	scanf("%d%d%llu%llu",&n,&m,&a1,&a2);
	gen(n,a1,a2);
	for(int i=1;i<=n;i++)
	{
		for(int j=0;j<16;j++)
		{
			int s=0;
			for(int k=0;k<16;k++)
				s|=::s[i][j<<4|k]<<k;
			g[j][s].push_back(i);
		}
	}
	while(m--)
	{
		scanf("%s%d",str,&k);
		for(int j=0;j<256;j+=4){	
			int s=str[j>>2];
			if(s<58)
				s-=48;
			else
				s=s-'A'+10;
			p[j]=(s>>3&1)^lst;
			p[j+1]=(s>>2&1)^lst;
			p[j+2]=(s>>1&1)^lst;
			p[j+3]=(s&1)^lst;
		}
		lst=0;
		for(int i=0;i<16;i++)
		{
			int s=0;
			for(int j=0;j<16;j++)
				s|=p[i<<4|j]<<j;
			for(int j=0;j<g[i][s].size();j++)
				if((p^::s[g[i][s][j]]).count()<=k)
					lst=1,j=1000000000;
			if(lst)
				break;
		}
		putchar(lst+48),puts("");
	}
    return 0;
}

标签:10,P7738,01,15,times,NOI2021,le,Bob,量子
From: https://www.cnblogs.com/mekoszc/p/17437392.html

相关文章

  • Matlab基于量子遗传算法的函数寻优方法。 量子遗传算法QGA是量
    Matlab基于量子遗传算法的函数寻优方法。量子遗传算法QGA是量子计算与遗传算法相结合的产物,是一种新发展起来的概率进化算法。代码可正常运行ID:629677955279662......
  • 【密码】量子密钥分发密钥率仿真附MATLAB代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • 量子相关计算基本操作
    NOT,SWAPC-NOT量子门量子门NOT门NOT:输入与输出相反。量子门SWAP门SWAP:交换两个输入量子门C-NOT门 C-NOT:Controlled-NOT根据控制位决定输入是否变为相反的值。控制位为0,输出为目标值原值;控制位为1,输出为目标值的非值。此过程控制位的值保持不变。 C-NOT门中,控制位也......
  • 量子计算的安全问题
    通信安全不可破解的通信2017年,中国首次使用量子计算来保护一个经由卫星传输的视频通话,成为了世界上第一个这样做的国家(可以阅读LeeBillings2017年的文章:《中国打破“幽灵般的遥距”纪录,为量子互联网做准备》)。在经典的安全通信中,已经有了各种工具,例如一次性密码本或更常见的加......
  • 最简单一维量子链求解实例
    写在前面:5年前的笔记,再次做个备份.假设器件长度为\(L\),均匀分成\(N+1\)份,网格spacing为\(a=L/(N+1)\).\[H\varphi=-\frac{\hbar^2}{2m}\frac{\partial^2}{\partialx^2}\varphi=E\varphi\]因为\(\varphi(0)=\varphi(N+1)=0\),所以\[\varphi(0)+\var......
  • 量子密钥分发光网络-仿真研究
    1.获取拉满散射噪声系数谱。从一个曲线图上获取每个点的具体数据-小工具:(注册免费使用21天)http://www.getdata-graph-digitizer.com/registration.php......
  • 量子计算技术的前沿探索:量子比特和量子通信的应用
    ​ 量子计算技术是当前科技领域的热门话题之一,它的出现将会对计算机科学、密码学、物理学等领域产生深远的影响。量子计算机的核心是量子比特,它是量子计算机中的基本单位,与传统计算机中的比特不同,量子比特具有超强的计算能力和信息处理能力。量子比特的应用非常广泛,它可以用于解......
  • 量子计算机技术的发展与应用前景
    ​ 随着科技的不断发展,量子计算机技术也逐渐成为了热门话题。量子计算机是一种基于量子力学原理的计算机,它的运算速度比传统计算机快得多。量子计算机技术的发展和应用前景备受关注,下面我们来详细了解一下。首先,量子计算机技术的发展历程。量子计算机的概念最早由理论物理学家理......
  • 量子图形加密算法的MATLAB代码实现
    一、概述目前主流的量子图形加密算法有量子像素编码算法(QuantumImagePixelEncoding,QIPE)、量子像素置乱算法(QuantumImagePixelScrambling,QIPS)等。一个简......
  • 开源量子计算编程框架软件介绍
    1.编程框架简介​在编程领域,软件框架是指一种抽象形式,它提供了一个具有通用功能的软件,这些功能可以由使用者编写代码来有选择的进行更改,从而提供服务于特定应用的软件。可......