2016年中国大学生程序设计竞赛(合肥)-重现赛1008 HDU 5968
异或密码
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 19 Accepted Submission(s): 9
}。对于这个序列的一个连续子序列{al,al+1,…,ar
}晨晨可以求出其中所有数异或的结果 alxoral+1xor...xorar
其 中xor表示位异或运算,对应C、C++、 Java等语言中的^运算。
小璐提出了M个询问,每个询问用一个整数 xi
描述。
对于每个询问,晨晨需要找到序列{ai
}的所有连续子序列,求出每个子序列异或的结果,找到所有的结果中与 xi
之差的绝对值最小的一个,并告诉小璐相应子序列的长度。
若有多个满足条件的连续子序列,则告诉小璐这些子序列中最长的长度。
每组数据共两行。
第一行包含N+1个非负整数。其中第一个数为N,表示序列的长度;接下来N 个数,依次描述序列{ ai
}中的每个数。
第二行包含M+1个整数。其中第一个数为M,表示询问的个数;接下来M个数 xi
,每个数对应题目描述中的一个询问。
保证 1 <= N <= 100,1 <= M <= 100,ai
<= 1024,|xi
| <= 1024,数据组数 <= 100。
#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的更多相关文章
- 2016年中国大学生程序设计竞赛(合肥)-重现赛1001 HDU 5961
传递 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...
- 2016年中国大学生程序设计竞赛(合肥)-重现赛1009 HDU 5969
最大的位或 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submi ...
- HDU 5963 朋友 【博弈论】 (2016年中国大学生程序设计竞赛(合肥))
朋友 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Descr ...
- HDU 5969 最大的位或 【贪心】 (2016年中国大学生程序设计竞赛(合肥))
最大的位或 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem De ...
- HDU 5968 异或密码 【模拟】 2016年中国大学生程序设计竞赛(合肥)
异或密码 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem Des ...
- HDU 5961 传递 【图论+拓扑】 (2016年中国大学生程序设计竞赛(合肥))
传递 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem ...
- HDU 5965 扫雷 【模拟】 (2016年中国大学生程序设计竞赛(合肥))
扫雷 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submissi ...
- HDU 5937 Equation 【DFS+剪枝】 (2016年中国大学生程序设计竞赛(杭州))
Equation Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- HDU 5936 Difference 【中途相遇法】(2016年中国大学生程序设计竞赛(杭州))
Difference Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
随机推荐
- 使用 WinHttp 实现文件下载
#include <Windows.h> #include <Winhttp.h> #pragma comment(lib,"Winhttp.lib") t ...
- Bootstrap <基础二十九>面板(Panels)
Bootstrap 面板(Panels).面板组件用于把 DOM 组件插入到一个盒子中.创建一个基本的面板,只需要向 <div> 元素添加 class .panel 和 class .pa ...
- jquery tab 插件
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JS中函数的调用和this的值
调用每一个函数会暂停当前函数的执行,传递控制权和参数给新函数.除了声明时定义的形式参数,每个函数还接收两个附加的参数:this 和 arguments. 参数this在面向对象编程中非常重要,他的值取 ...
- 关于DMA和它的仇家
[基础知识]什么叫做DMA?DMA=Direct Memory Access.这是一种通过硬件实现的数据传输机制.简单的说,就是不在CPU的参与下完成数据的传输.[/基础知识]不太明白?我举个简单的例 ...
- visor 发布
2014-4-10 visor.com.cn 的域名备案终于审核通过了.http://www.visor.com.cn 终于可以访问了,欢迎大家使用免费的线框图应用设计工具.
- C#中Thread与ThreadPool的比较
最近同事在编写一个基于UPD RTP协议的通信软件,在处理接收Listen时,发现了一个问题到底是用Thread还是ThreadPool呢? 我看同事的问题比较有典型性,还是做以整理培训一下吧 Thr ...
- (转)在oracle中varchar和varchar2有什么区别?
1.varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节: 2.VARCHAR2把空串等同于null处理,而varchar仍 ...
- 杭电ACM1002
原题:http://acm.hdu.edu.cn/showproblem.php?pid=1002 #include <stdio.h> #include <string.h> ...
- C++ 之 auto_ptr and shared_ptr
1.auto_ptr 这个所谓的只能指针有点鸡肋! 没有引用计数,而且还有一个所有权转移的情况! 当所有权转移后,以前的auto_ptr将会成为null 2.shared_ptr 增加了引用计数,没 ...