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 ...
随机推荐
- linux中用户的主目录~
-在Linux中代表用户主目录 对一般用户,-表示/home/(用户名) 对于root用户,-表示/root 如果要查看-的真实面貌,可以先进入-目录,然后用pwd -P命令查看-的绝对路径 cd ~ ...
- string类实现(C++)
class CMyString { friend std::ostream& operator<<( std::ostream& os, const CMyString&a ...
- Tomcat容器虚拟路径设置
1.[官方文档]在tomcat\conf下server.xml中找到 <Host name="localhost" appBase="webapps" u ...
- js图片拖放原理(很简单,不是框架,入门基础)
<html> <meta> <script src='jquery-1.8.3.min.js'></script> <script> /* ...
- How to realize the double os in the win8 background.
Goal: to realize the Ubantu in the windows system os computer. Tools: Ubantu install USB MSD, Soft ...
- Java HttpGet
String urlStr ="https://qyapi.weixin.qq.com/cgi-bin/gettoken?a=a&b=b"; URL url = null; ...
- .NET3.5项目转.NET2.0项目技巧
最近有一个项目,一开始开发是用VS2008(.NET3.5)开发的,该项目是一个Windorm客户端软件,由于在大规模的推广过程中,发现在安装.NET3.5Framework的时候浪费了太多时间,而且 ...
- 学习linux/unix编程方法的建议(转)
假设你是计算机科班出身,计算机系的基本课程如数据结构.操作系统.体系结构.编译原理.计算机网络你全修过 我想大概可以分为4个阶段,水平从低到高从安装使用=>linux常用命令=>linux ...
- SharePoint 2013 中的 PowerPoint Automation Services
简介 许多大型和小型企业都将其 Microsoft SharePoint Server 库用作 Microsoft PowerPoint 演示文稿的存储库.所有这些企业在 ...
- iOS 视频录制、压缩、上传
项目中实现功能 视频的录制.压缩.上传 首先调用系统的相机或相册 iOS录制的视频是mov格式的,安卓和PC不支持,因此要转换成MP4,并且要压缩. 获取到视频或者照片,处理的方法 下面两个方法是获取 ...