[Lydsy1711月赛]分割序列

Time Limit: 5 Sec  Memory Limit: 256 MB
Submit: 213  Solved: 97
[Submit][Status][Discuss]

Description

对于一个长度为n的非负整数序列b_1,b_2,...,b_n,定义这个序列的能量为:f(b)=max{i=0,1,...,n}((b_1 xor b
_2 xor...xor b_i)+(b_{i+1} xor b_{i+2} xor...xor b_n))其中xor表示按位异或(XOR),给定一个长度为n的非
负整数序列a_1,a_2,...,a_n,请计算a的每个前缀的能量值。

Input

第一行包含一个正整数n(n<=300000),表示序列a的长度。
第二行包含n个非负整数a_1,a_2,...,a_n(0<=a_i<=10^6),依次表示a中每个元素的值。
 

Output

包含n行,每行一个整数,即a每个前缀的能量值。

 

Sample Input

5
1 2 3 4 5

Sample Output

1
3
6
10
9

HINT

 

Source

本OJ付费获取

题解:这道题目开始的时候发现很难解决,什么可持久化trie数貌似都不行,

   因为对于当前位是1的那么前面不管填0,还是1都是可以的,所以难以解决,

   然后后来baidu了一下题解,(本来以为会很难),然后发现题解代码居然如此的短,

   题解的f[i]表是i,包涵i的数的最小位置,这个是对于一个1的或来说的,

   比如00001 被 00011 00101 01001 10001 这些位置上的数都代表什么呢?

   所以对于寻找一个数的时候,比如1001这个数的时候,如果当前的位置上是1,那么不用管,如果当前位置上是0,那么

   需要1,所以就到当前位上有1的找。

   所以这个问题本质是什么,就是对于一个数1的位置上,需要找1的时候可以确定1这个位置是有数的,二对于其它位置是可以不管的,

   但是都要包涵其它位置,所以now这个的意义就是,now中 1的位置就是 1,其它位置是不确定,而且位置前面的比后面的优。

 #include<cstdio>
#include<algorithm>
#include<iostream>
#include<cstring>
using namespace std;
const int N=;
int n;
int a[N];
int f[];
int main()
{
memset(f,,sizeof(f));
scanf("%d",&n);
for (int u=;u<=n;u++)
{
scanf("%d",&a[u]);
a[u]=a[u]^a[u-];
f[a[u]]=min(f[a[u]],u);
}
for (int u=;u<=;u++)
for (int i=;i<=;i++)
if (!(i>>u&)) f[i]=min(f[i],f[i|(<<u)]);
for (int u=;u<=n;u++)
{
int now=;
for (int i=;i>=;i--)
if (!(a[u]>>i&)&&f[now|(<<i)]<=u) now=now|(<<i);
printf("%d\n",now+(a[u]^now));
}
}

最新文章

  1. codeforces 286 div2 B
  2. 【Android】设置 LinearLayout 的样式
  3. 4M宽带一般最大的下载速度是多少?
  4. [LeetCode] Fraction to Recurring Decimal 哈希表
  5. firefox(ff)下无法显示bootstrap图标问题的解决方案(转)
  6. contentProvider
  7. Recover damage pictures to see the crime scene
  8. javascript笔记——图片大小检测
  9. php之上传小案例,根据时间:月日分创建目录并随机生成文件名
  10. (?m) 可以让.去匹配换行
  11. c++,派生类对象可以对基类赋值,基类对派生类不可以赋值
  12. Linux 系统命令总结
  13. Delphi xe7并行编程快速入门(转)
  14. 洛谷 P1972 [SDOI2009]HH的项链【莫队算法学习】
  15. PostgreSQL 10.7 linux 主从配置
  16. QEMU KVM Libvirt手册(7): 硬件虚拟化
  17. jumpserver堡垒机安装
  18. LeetCode – Number of Islands II
  19. $(document).ready和window.onload 简单分析区别
  20. JavaScript学习复习

热门文章

  1. POJ 3210 : Coins
  2. Prime Ring Problem (DFS练习题)
  3. python2.7入门---file(文件)&amp;OS 文件&amp;目录方法
  4. Java集合类面试题
  5. samba与apache配置使用
  6. php杂记——2(数组的使用)
  7. linux开发基本库
  8. Sql面试题之三(难度:简单| 含答案)
  9. Linux通配符与特殊符号知识大全汇总
  10. DCGAN: &quot;Unsupervised Representation Learning with Deep Convolutional Generative Adversarial Network&quot; Notes