NEFU 1248 智力异或(字典树)

2024-04-09 13:08
文章标签 字典 nefu 异或 智力 1248

本文主要是介绍NEFU 1248 智力异或(字典树),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

智力异或

Problem:1248
Time Limit:2000ms
Memory Limit:65535K

Description

有一个数列包含n个正整数a[1]~a[n](1<=n<1e5,0<=a[i]<1e9),现在有q次操作(q<1e5),每次操作是以下两种操作中的一种:1、输入x,对这n个数分别异或x;2、输入x,求数列中的某个数与x异或的最大值(即从数组中找一个数,使其与x异或值最大);

Input

第一行为T,表示有T(T<=10)组数据,每组数据的第一行为n和q,表示这个数列长为n,q次操作。然后输入这n个数。接下来,每次操作输入一行两个数op(op为1或者2)和x(0<=x<1e9),op=1表示进行操作1,op=2表示进行操作2;

Output

每次进行操作2时,用一行输出最大的异或值;

Sample Input

1
4 3
6 7 5 4
1 3
2 4
2 5

Sample Output

3
3

Hint

Source

CJJ
题意:中文题。

思路:
建一棵字典树,里面存的是从高位到低位的二进制。因为在查询的时候,高位的影响更大,所以应该优先考虑高位,把高位放在前面。

在进行op1操作时候,并不用遍历字典树将所有数都与x异或。只需要存下一个y=0来与x异或就行。因为它们在op1过程中中间改变的(a^b^...^z)是一定的,只需要用y来记录下来再进行op2操作时候传入x^y就相当于那棵树上的所有节点已经完成了之前op1的操作。

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn=1e5+5;
int cnt,root;
struct node
{int next[2];
}q[40*maxn];
void in(int root,int n)
{for(int i=30;i>=0;i--){int x=(n>>i)&1;if(q[root].next[x]==0){q[root].next[x]=++cnt;}root=q[root].next[x];}
}
int query(int root,int n)
{int ans=0;for(int i=30;i>=0;i--){ans<<=1;int x=(n>>i)&1;if(q[root].next[!x]!=0){ans=ans|(!x);root=q[root].next[!x];}else{ans=ans|x;root=q[root].next[x];}}return ans^n;
}
int main()
{int t,n,qq,x,o,y;scanf("%d",&t);while(t--){y=0,cnt=0,root=0;memset(q,0,sizeof(q));scanf("%d%d",&n,&qq);for(int i=1;i<=n;i++){scanf("%d",&x);in(root,x);}for(int i=1;i<=qq;i++){scanf("%d%d",&o,&x);if(o==1){y^=x;}else{printf("%d\n",query(root,y^x));}}}return 0;
}


这篇关于NEFU 1248 智力异或(字典树)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888234

相关文章

POJ2001字典树

给出n个单词,求出每个单词的非公共前缀,如果没有,则输出自己。 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.io.UnsupportedEncodingException;

python 实现第k个字典排列算法

第k个字典排列算法介绍 "第k个字典排列"算法通常指的是在给定的字符集合(例如,字符串中的字符)中,找到所有可能排列的第k个排列。这个问题可以通过多种方法解决,但一个常见且高效的方法是使用“下一个排列”算法的变种,或称为“第k个排列”的直接算法。 方法一:使用“下一个排列”的变种 生成所有排列:首先生成所有排列,但显然这种方法对于较大的输入集合是不切实际的,因为它涉及到大量的计算和存储。 排序

POJ3617(字典序最小问题)

书中43页 此题有坑点,PE了40分钟.也是醉了....题目要求每80个字符才换行,而且最后一个如果恰好就不用换,这不是无聊嘛....... #include <iostream>#include <cstdio>#include <cstring>using namespace std;int n,m;char S[2100],P[2100];int main(){#ifd

POJ 2001 Shortest Prefixes(字典树入门)

题目: http://poj.org/problem?id=2001 题意: 找到多个字符串中,各自唯一的最短子串,例如 carte 与 carce 各自唯一的最短子串为cart与carc,即不会与其它字符串的子串重复。 思路: 字典树 解题心得: 更新关键值的时机很重要 代码: #include<stdio.h>#include<string>typedef str

【OpenCV2.2】图像的算术与位运算(图像的加法运算、图像的减法运算、图像的融合)、OpenCV的位运算(非操作、与运算、或和异或)

1 图像的算术运算 1.1 图像的加法运算 1.2 图像的减法运算 1.3 图像的融合 2 OpenCV的位运算 2.1 非操作 2.2 与运算 2.3 或和异或 1 图像的算术运算 1.1 图像的加法运算 add opencv使用add来执行图像的加法运算 图片就是矩阵, 图片的加法运算就是矩阵的加法运算, 这就要求加法运算的两张图shape必须是相同的. # 图片加法imp

用异或交换两个整数的陷阱

前面我们谈到了,可用通过异或运算交换两个数,而不需要任何的中间变量。 如下面: void exchange(int &a, int &b) {     a ^= b;     b ^= a;     a ^= b; } 然而,这里面却存在着一个非常隐蔽的陷阱。 通常我们在对数组进行操作的时候,会交换数组中的两个元素,如exchang(&a[i], &b[j]),

Oracle数据库(数据字典、表空间、表的创建、视图)

知识点引用: http://www.2cto.com/database/201207/142874.html http://blog.csdn.net/haiross/article/details/11772847 一. 彻底卸载Oracle 方式1、重装操作系统 方式2、 2.1 DBCA删除数据库开始 → 程序 → Oracle → 开发与移植工具 → Datab

Python的字符串,list,tuple,set,字典操作详解

1.字符串python是要创建成字符串的元素,其中的每个字母都是单一的子串,把它放在' '单引号或是'' ''引号中,就完成了python 字符串的创建。#str强制转换>>> a=123>>> b=str(a) #将整数转化为字符串>>> b'123'>>> a=[1,2,3]>>> b=str(a) #将list转化为字符串>>> b'[1, 2, 3]'#字符串下

OC中数组、字典、集合常用方法的运用

/* ====================== 一 NSArray========================          1.创建对象          1.1初始化方法(2) //一般程序有问题先检查初始化          1.2类方法          1.3字面量方法          2.数组查找          2.1通过下标访问对象[ .[i]]

python pickle 模块用于保存python内存数据(包括实例对象、字典、列表等所有python中的数据)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言基本用法 前言 Python 的 pickle 模块用于序列化和反序列化 Python 对象。这意味着你可以将 Python 对象(如列表、字典、类实例等)转换为字节流(序列化),并将其保存到文件中或在网络上传输,然后在需要的时候将其恢复为原始 Python 对象(反序列化)。 常见用途