Consecutive Sum LightOJ - 1269(区间异或和)
Consecutive Sum
又来水一发blog...
本来是昨天补codechef的题,最后一道题是可持久化字典树,然后去黄学长博客看了看
觉得字典树写法有点不太一样,就想着用黄学长的板子写码几道题吧...
最后发现...其实是可持久化字典树跟普通字典树写法不一样...我好傻逼...
区间异或和
可以先把前缀异或和插入到字典树中,然后去贪心
求最大值就是要求从高到低尽量不一样
高位不一样优先
用一个bit数组来存放好看多了
偷偷摸摸顺便学了快读板子...虽说可能没啥用...
#include <bits/stdc++.h>
using namespace std; const int maxn = 2e6 + ; int sum[ + ];
int ans1, ans2;
int bit[];
inline int read() {
int x = , f = ; char ch = getchar();
while (ch < '' || ch > '') { if (ch == '-') f = -; ch = getchar(); }
while (ch >= '' && ch <= '') { x = x * + ch - ''; ch = getchar(); }
return x * f;
} struct Trie {
int tol;
int Next[maxn][];
void init() {
tol = ;
memset(Next, , sizeof(Next));
}
void insert(int x) {
int root = ;
for (int i = ; i >= ; i--) {
int id = x & bit[i]; id >>= i;
if (!Next[root][id]) Next[root][id] = ++tol;
root = Next[root][id];
}
}
void query(int x) {
int temp1 = , root1 = , root2 = , temp2 = ;
for (int i = ; i >= ; i--) {
int id = x & bit[i]; id >>= i;
if (Next[root1][id ^ ]) root1 = Next[root1][id ^ ], temp1 += bit[i];
else root1 = Next[root1][id];
if (Next[root2][id]) root2 = Next[root2][id];
else root2 = Next[root2][id ^ ], temp2 += bit[i];
}
ans1 = max(ans1, temp1);
ans2 = min(ans2, temp2);
}
} trie; int main() {
bit[] = ; for(int i = ; i <= ; i++) bit[i] = bit[i-] << ;
int T;
T = read();
// cin >> T;
int kase = ;
while (T--) {
int n = read();
// Trie trie;
trie.init();
ans1 = ;
ans2 = 0x3f3f3f3f;
trie.insert();
for (int i = ; i <= n; i++) {
int x; cin >> x;
sum[i] = sum[i-] ^ x;
trie.query(sum[i]);
trie.insert(sum[i]);
}
printf("Case %d: %d %d", ++kase, ans1, ans2);
puts("");
}
return ;
}
Consecutive Sum LightOJ - 1269(区间异或和)的更多相关文章
- LightOJ 1269 Consecutive Sum (Trie树)
Jan's LightOJ :: Problem 1269 - Consecutive Sum 题意是,求给定序列的中,子序列最大最小的抑或和. 做法就是用一棵Trie树,记录数的每一位是0还是1.查 ...
- 1269 - Consecutive Sum
1269 - Consecutive Sum PDF (English) Statistics Forum Time Limit: 3 second(s) Memory Limit: 64 MB ...
- 洛谷 P2574 XOR的艺术(线段树 区间异或 区间求和)
To 洛谷.2574 XOR的艺术 题目描述 AKN觉得第一题太水了,不屑于写第一题,所以他又玩起了新的游戏.在游戏中,他发现,这个游戏的伤害计算有一个规律,规律如下 1. 拥有一个伤害串为长度为n的 ...
- hdoj 1977 Consecutive sum II
Consecutive sum II Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- HDOJ(HDU) 1977 Consecutive sum II(推导、、)
Problem Description Consecutive sum come again. Are you ready? Go ~~ 1 = 0 + 1 2+3+4 = 1 + 8 5+6+7+8 ...
- BZOJ 4260 Codechef REBXOR (区间异或和最值) (01字典树+DP)
<题目链接> 题目大意:给定一个序列,现在求出两段不相交的区间异或和的最大值. 解题分析: 区间异或问题首先想到01字典树.利用前缀.后缀建树,并且利用异或的性质,相同的两个数异或变成0, ...
- CF 617E【莫队求区间异或和】
E. XOR and Favorite Number time limit per test 4 seconds memory limit per test 256 megabytes input s ...
- P3943 星空 区间异或差分
\(\color{#0066ff}{ 题目描述 }\) 逃不掉的那一天还是来了,小 F 看着夜空发呆. 天上空荡荡的,没有一颗星星--大概是因为天上吹不散的乌云吧. 心里吹不散的乌云,就让它在那里吧, ...
- bzoj 2819 Nim dfn序+树状数组维护区间异或值
题目大意 著名游戏设计师vfleaking,最近迷上了Nim.普通的Nim游戏为:两个人进行游戏,N堆石子,每回合可以取其中某一堆的任意多个,可以取完,但不可以不取.谁不能取谁输.这个游戏是有必胜策略 ...
随机推荐
- SpringBoot技术栈搭建个人博客【后台开发】
前言:在之前,我们已经完成了项目的基本准备,那么就可以开始后台开发了,突然又想到一个问题,就是准备的时候只是设计了前台的RESTful APIs,但是后台管理我们同样也是需要API的,那么就在这一篇里 ...
- Windows环境下安装配置Mosquitto服务及入门操作介绍
关键字:在windows安装mosquitto,在mosquitto中配置日志,在mosquitto中配置用户账号密码 关于Mosquitto配置的资料网上还是有几篇的,但是看来看去,基本上都是基于L ...
- javascript小记五则:用JS写一个图片左右自由滚动的“跑马灯”效果
之前看了很多百度搜索出的东西,十个有九个是不能实用的,个个讲的都不详细,今天详细给大家讲解下关于这个图片“跑马灯”滚动效果,源码如下: <!DOCTYPE html PUBLIC "- ...
- C# 插入文本框到PPT幻灯片
概述 在文本框中我们可以实现的操作有很多,如插入文字.图片.设置字体大小.颜色.文本框背景填充.边框设置等.下面的示例中,将介绍通过C# 在PPT幻灯片中插入幻灯片的方法. 示例中包含了以下要点: 插 ...
- java中求质数(素数)的问题
这篇笔记讲讲关于java中质数的问题. 一.什么是质数(素数)? 定义:质数又称素数.一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数:否则称为合数.它可以有无限个数. 二.ja ...
- nginx系列8:反向代理和负载均衡原理
反向代理是nginx的一个非常重要的功能. 反向代理 nginx支持四层反向代理和七层反向代理,如下图. 负载均衡 负载均衡是实现服务高性能和高可用的重要手段,而nginx是实现负载均衡的重要工具.
- Web 性能优化:Preload与Prefetch的使用及在 Chrome 中的优先级
摘要: 理解Preload与Prefetch. 原文:Web 性能优化:Preload,Prefetch的使用及在 Chrome 中的优先级 作者:前端小智 Fundebug经授权转载,版权归原作者所 ...
- xml代码 解决eclipse乱码问题
<filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springf ...
- OpenCV尝试
我们来尝试,使用OpenCV来读入本地的一张图片,并使用库函数将其水平翻转.垂直翻转以及边缘提取,后将结果文件存入本地. 工具:VS2017 OpenCV4.0.1 怎么配置opencv/报错怎么办 ...
- 轻松学习UML之用例图,时序图
本文主要讲解UML图中的用例图(Use Case Diagram)和时序图(Sequence Diagram)相关内容,如有不足之处,还请指正. 概述 统一建模语言(UML,UnifiedModeli ...