异或密码

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 19    Accepted Submission(s): 9

Problem Description
晨晨在纸上写了一个长度为N的非负整数序列{ai

}。对于这个序列的一个连续子序列{al,al+1,…,ar

}晨晨可以求出其中所有数异或的结果 alxoral+1xor...xorar

其 中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
 
 
Source
题意:中文题面
题解:预处理出所有区间的异或值并记录最大的长度,二分处理。
二分又写挫......orzzzzzz 太菜
 
 #include<iostream>
#include<cstdio>
#include<cmath>
#define ll __int64
using namespace std;
int t;
int n,m;
int a[];
int b[];
int c[];
int d[];
struct node
{
int w;
int kuan;
} N[];
int abs(int x)
{
if(x<)
x=-x;
return x;
}
int main()
{
scanf("%d",&t);
for(int i=; i<=t; i++)
{
scanf("%d",&n);
for(int j=; j<=n; j++)
scanf("%d",&a[j]);
scanf("%d",&m);
for(int j=; j<=m; j++)
scanf("%d",&b[j]);
int exm=;
c[]=;
for(int j=; j<=n; j++)
{
exm^=a[j];
c[j]=exm;
}
for(int j=; j<=; j++)
d[j]=-;
for(int j=; j<=n; j++)
for(int k=j; k<=n; k++)
d[c[j-]^c[k]]=max(d[c[j-]^c[k]],k-j+); int flag=;
for(int j=; j<=; j++)
{
if(d[j]!=-)
{
N[flag].w=j;
N[flag].kuan=d[j];
flag++;
}
}
for(int j=; j<=m; j++)
{
int l=,r=flag-,mid;
if(N[l].w>=b[j]){
printf("%d\n",N[l].kuan);
continue;
}
if(N[r].w<=b[j])
{
printf("%d\n",N[r].kuan);
continue;
}
while(l<r)
{
mid=(l+r)>>;
if(N[mid].w<=b[j])
l=mid+;
else
r=mid;
}
if(abs(N[l].w-b[j])>abs(N[l-].w-b[j]))
printf("%d\n",N[l-].kuan);
if(abs(N[l].w-b[j])<abs(N[l-].w-b[j]))
printf("%d\n",N[l].kuan);
if(abs(N[l].w-b[j])==abs(N[l-].w-b[j]))
printf("%d\n",max(N[l].kuan,N[l-].kuan));
}
printf("\n");
}
return ;
}
/*
2
2 1 1
2 0 2
3 1 2 4
4 5 6 7 8
*/

2016年中国大学生程序设计竞赛(合肥)-重现赛1008 HDU 5968的更多相关文章

  1. 2016年中国大学生程序设计竞赛(合肥)-重现赛1001 HDU 5961

    传递 Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...

  2. 2016年中国大学生程序设计竞赛(合肥)-重现赛1009 HDU 5969

    最大的位或 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submi ...

  3. HDU 5963 朋友 【博弈论】 (2016年中国大学生程序设计竞赛(合肥))

    朋友 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Problem Descr ...

  4. HDU 5969 最大的位或 【贪心】 (2016年中国大学生程序设计竞赛(合肥))

    最大的位或 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Problem De ...

  5. HDU 5968 异或密码 【模拟】 2016年中国大学生程序设计竞赛(合肥)

    异或密码 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Problem Des ...

  6. HDU 5961 传递 【图论+拓扑】 (2016年中国大学生程序设计竞赛(合肥))

    传递 Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)     Problem ...

  7. HDU 5965 扫雷 【模拟】 (2016年中国大学生程序设计竞赛(合肥))

    扫雷 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submissi ...

  8. HDU 5937 Equation 【DFS+剪枝】 (2016年中国大学生程序设计竞赛(杭州))

    Equation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  9. HDU 5936 Difference 【中途相遇法】(2016年中国大学生程序设计竞赛(杭州))

    Difference Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total ...

随机推荐

  1. vector algorithm find

    本来想着申请了博客园以后 我要写的博客都必须是有深度有内涵的...好吧 结果我只能说我想多了 还是得一步一步慢慢来 最近小学期的任务是要做一个学校食堂餐卡管理系统     有“严重拖延症”的我  果然 ...

  2. 关闭SqlServer连接

    经常使用需要还原数据库又不想关闭已经打开的画面,所以直接上 CREATE PROCEDURE [dbo].[StopLogin] ) AS DECLARE ), ) BEGIN IF (@Dname ...

  3. git 小结

    git cherry-pick de0ec64  可将另一个分支中的提交 cherry-pick到当前分支来

  4. [linux-内核][转]内核日志及printk结构浅析

    这段时间复习了一下内核调试系统,注意看了一下printk的实现以及内核日志的相关知识,这里做一下总结. 1.问题的引出: 做DPDK项目时,调试rte_kni.ko时,发现printk并不会向我们想想 ...

  5. odi 12.2.1.1新特性

    ODI 12.2.1.1现在已经发布,也可以OTN上下载,主要变化: Hyperion Essbase and Hyperion Planning 知识模块 Hyperion Essbase and ...

  6. IIS下注册COM组件(转)

    以Excel为例 问题描述: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误: 80070005基 ...

  7. OpenCV在VS2005下的配置

    http://bbs.ednchina.com/BLOG_ARTICLE_3019518.HTM 这是自己今天刚弄好了之后的一点经历.不是很详细.以后有时间一定要整理整理.

  8. Javascript常用方法函数收集(一)

    1.字符串长度截取 function cutstr(str, len) { var temp, icount = 0, patrn = /[^\x00-\xff]/, strre = "&q ...

  9. Python基础知识之排序法

    在Python开发中,我们会经常使用到排序法,排序的最简单的方法是用sort(list)函数,它接受一个列表并返回与有序的元素一个新的列表. 原始列表不被改变. a = [5, 1, 4, 3]    ...

  10. url中

    url中汉字被转换为UTF-8,通过此网址可以解析UTF-8编码.在地址栏中输入文字或者其它的,则可能输入法或者是相关的程序进行解析. http://www.mytju.com/classcode/t ...