HDU 5968 异或密码

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)

 

Problem Description - 题目描述

晨晨在纸上写了一个长度为N的非负整数序列{ai}。对于这个序列的一个连续子序列{al, al+1, …,ar}晨晨可以求出其中所有数异或的结果 al xor al + 1xor ... xor ar其 中xor表示位异或运算,对应C、C++、 Java等语言中的^运算。
小璐提出了M个询问,每个询问用一个整数 xi描述。
对于每个询问,晨晨需要找到序列{ai}的所有连续子序列,求出每个子序列异或的结果,找到所有的结果中与 xi之差的绝对值最小的一个,并告诉小璐相应子序列的长度。
若有多个满足条件的连续子序列,则告诉小璐这些子序列中最长的长度。
 
Input - 输入
包含多组测试数据,第一行一个正整数T,表示数据组数。
每组数据共两行。
第一行包含N+1个非负整数。其中第一个数为N,表示序列的长度;接下来N 个数,依次描述序列{ ai}中的每个数。
第二行包含M+1个整数。其中第一个数为M,表示询问的个数;接下来M个数 xi,每个数对应题目描述中的一个询问。
保证 1 <= N <= 100,1 <= M <= 100,ai <= 1024,|xi| <= 1024,数据组数 <= 100。
Output - 输出

对于每组数据输出M + 1行。前M行对应晨晨M个询问的回答,第M + 1行为空行
 

Sample Input - 输入样例

2
2 1 1
2 0 2
3 1 2 4
3 10 5 1

Sample Output - 输出样例

2
1 3
2
1

题解

  水题。
  枚举所有子序列的异或值,然后花式查询即可,数据比较小,不用管时间。

  输出是每组数据后面都要有额外的回车,不然会PE……

代码 C++

 #include<cstdio>
#include <cstring>
#include <algorithm>
#include <cstdlib>
#define mx 1<<11
int data[], len[mx];
int main(){
int t, n, m, i, j, tmp, l, r;
scanf("%d", &t);
while (t--){
memset(len, , sizeof(len));
scanf("%d", &n);
for (i = ; i < n; ++i) scanf("%d", data + i);
for (i = ; i < n; ++i){
tmp = ;
for (j = i; j < n; ++j){
tmp ^= data[j];
len[tmp] = std::max(len[tmp], j - i + );
}
}
scanf("%d", &m);
for (i = ; i < m; ++i){
scanf("%d", &tmp); l = r = -;
tmp = std::max(tmp, );
for (j = tmp; j < mx; ++j) if (len[j]) break;
if (j < mx) l = j;
for (j = tmp - ; ~j; --j) if (len[j]) break;
if (~j) r = j;
if (~(l | r)){
if (abs(tmp - l) < abs(tmp - r)) printf("%d\n", len[l]);
else if (abs(tmp - l) > abs(tmp - r)) printf("%d\n", len[r]);
else printf("%d\n", std::max(len[l], len[r]));
}
else printf("%d\n", len[- * l * r]);
}
puts("");
}
return ;
}

最新文章

  1. Bootstrap学习笔记(一)
  2. vim 使用总结
  3. win7 IIS发布项目遇到的问题
  4. C++实现有向权图的基本操作,界面友好,操作方便,运行流畅
  5. Java Collection集合接口
  6. HDU 2181 哈密顿绕行世界问题 (DFS)
  7. &lt;一&gt; ASP.NET Html 表单
  8. Python面向对象OOP
  9. 【最短路】NEERC15 F Froggy Ford(2015-2016 ACM-ICPC)(Codeforces GYM 100851)
  10. java-二分查找法
  11. hdu5086——Revenge of Segment Tree
  12. scapy流量嗅探简单使用
  13. C语言温度
  14. STM32的LED驱动程序
  15. Django 2.0 Release note阅读简记
  16. Jmeter、Java当double显示的数字过长时取消科学计数法显示
  17. C# Thread.Jion()
  18. impala系列: 时间函数
  19. 混合编译.c/.cpp与.cu文件
  20. 『TensorFlow』读书笔记_AlexNet

热门文章

  1. 经历alidns在国外的严重延时
  2. GCC-4.6.3编译linux2.6.32.12内核出现“重复的成员‘page’”错误的解决方法
  3. Samba文件服务器详细配置步骤
  4. cef 介绍
  5. js 获取根目录 获取参数
  6. 我的第一个hadoop程序
  7. JS数组操作示意图(shift,unshift,pop,push)
  8. MySql 绿色版配置
  9. iOS多线程同步锁
  10. jade模板