异或密码

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. C#简易一元二次求解器

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  2. javap反编译解释外部类直接使用内部类private字段的原理

    2016-07-04 15:56:39 我们都知道: 1.内部类可以直接访问外部类的private字段和方法: 2.非静态内部类持有外部类的引用: 3.外部类可以直接访问内部类的private字段和方 ...

  3. 【67测试20161116】【数论】【DP】【思维】

    第一题: LGTB 得到了一个序列,他想在这个序列中选择一个最长的连续子序列,使得这个子序列的最大公约数等于1.请告诉他他能得到的最大长度,如果没有这样的序列,输出-1. 对于50% 的数据,1 &l ...

  4. Android中View的事件分发机制

    简介 事件也称MotionEvent,事件分发机制就是对MotionEvent事件的分发过程,即当一个MotionEvent发生之后,系统需要把这个事件传递给一个具体的View. 点击事件的分发过程由 ...

  5. Haskell Tuple相关总结

    一.相关操作 zip:将两个List合并成一个元组序对的List. fst:返回元组序对第一个元素. snd:返回元组序对第二个元素. PS:元组序对是元组中只有两个元素的元组. 二.与List的比较 ...

  6. jquery qrcode参数

    { // render method: 'canvas', 'image' or 'div' render: 'canvas', // version range somewhere in 1 .. ...

  7. java目录与classpath

    目录结构 描述 jdk bin            编译器和工具 demo             演示 docs              HTML格式的类库文档 include         ...

  8. IE 文档模式

    <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv= ...

  9. Total Commander 8.52 Beta 1

    Total Commander 8.52 Beta 1http://www.ghisler.com/852_b1.php 10.08.15 Release Total Commander 8.52 b ...

  10. JPA使用入门

    JPA能干什么?我在前面一遍文章<初步了解JPA>基本描述了.不过你不需要点击回去再看.这里简单的再提一下JPA的功能,就是:(1)实现“对象-关系”映射:(2)对象持久化到数据库:(3) ...