【bzoj4260】【Codechef REBXOR】【trie】

2024-02-20 15:18
文章标签 trie codechef bzoj4260 rebxor

本文主要是介绍【bzoj4260】【Codechef REBXOR】【trie】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Description

Input

输入数据的第一行包含一个整数N,表示数组中的元素个数。
第二行包含N个整数A1,A2,…,AN。

Output

输出一行包含给定表达式可能的最大值。

Sample Input

5
1 2 3 1 2

Sample Output

6

HINT

满足条件的(l1,r1,l2,r2)有:(1,2,3,3),(1,2,4,5),(3,3,4,5)。

对于100%的数据,2 ≤ N ≤ 4*105,0 ≤ Ai ≤ 109。

题解:用trie树维护一个前缀最大值和一个后缀最大值即可.

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#define N 500010
using namespace std;
int a[N],ch[31*N][2],n,bin[N],cnt,l[N],r[N],x,ans;
void insert(int x){int now(0);for (int i=30;i>=0;i--){int t=x&bin[i];t>>=i;if (!ch[now][t]) ch[now][t]=++cnt;now=ch[now][t]; }	 
}
int query(int x){int now(0),ans(0);for (int i=30;i>=0;i--){int t=x&bin[i];t>>=i;if (ch[now][t^1]) now=ch[now][t^1],ans+=bin[i];else now=ch[now][t];}return ans;
}
int main(){scanf("%d",&n);for (int i=1;i<=n;i++) scanf("%d",&a[i]);bin[0]=1;for (int i=1;i<=n;i++) bin[i]=bin[i-1]*2;insert(0);for (int i=1;i<=n;i++) l[i]=max(l[i-1],query(x=x^a[i])),insert(x); memset(ch,0,sizeof(ch));insert(0);x=0;for (int i=n;i>=1;i--) r[i]=max(r[i+1],query(x=x^a[i])),insert(x);for (int i=1;i<=n-1;i++) ans=max(ans,l[i]+r[i+1]);cout<<ans<<endl; 
}


这篇关于【bzoj4260】【Codechef REBXOR】【trie】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/728638

相关文章

Python高效实现Trie(前缀树)及其插入和查找操作

Python高效实现Trie(前缀树)及其插入和查找操作 在Python面试中,考官通常会关注候选人的编程能力、问题解决能力以及对Python语言特性的理解。Trie(前缀树)是一种高效的数据结构,广泛应用于字符串处理、自动补全、拼写检查等场景。本文将详细介绍如何实现一个Trie,并提供插入和查找操作,确保代码实用性强,条理清晰,操作性强。 1. 引言 Trie(前缀树)是一种树形数据结构,

【codechef】 Prime Distance On Tree【求树上路经长度为i的路径条数】【点分治+FFT】

传送门:【codechef】 Prime Distance On Tree 点分治+FFT水题……竟然n*n爆int没发现…… 而且NTT TLE,FFT跑的超级快…… my  code: my~~code: #include <bits/stdc++.h>using namespace std ;typedef long long LL ;#define clr( a , x ) m

Trie 类型的题目总结

trie字典树可以用来查找单词或者搜索剪枝用。 Implement Trie (Prefix Tree) 实现一个 Trie,包含 insert, search, 和 startsWith 这三个方法。(模板必须记住;没有儿子建立儿子,有儿子走儿子;) class Trie {private class TrieNode {public TrieNode[] children;public b

【Trie树】模板题-POJ-2001

题意: 给你若干个单词,写出能每个单词的最短前缀 也就是说这个前缀能准确代表这个单词,和其他单词 without ambiguity  思路: 建立字典树存下这几个单词,ct 数组记录每个节点的子节点数,显然子树宽度只有1的话,这个单词就被确定了,改造一下我们的 find_word 函数就行啦 哦。。这个结构体要怎么搞还坑了我一下,要向下面那样定义! 代码: #include

Trie树专题

Intro:         为了高效的存储和查找字符串,集合的数据结构。,  板子: /*Trie树 —— 模板题 AcWing 835. Trie字符串统计*/int son[N][26], cnt[N], idx;// 0号点既是根节点,又是空节点// son[][]存储树中每个节点的子节点// cnt[]存储以每个节点结尾的单词数量// 插入一个字符串void insert(

数据结构-非线性结构-树形结构:Trie/字典树/前缀树【专门用于处理字符串类数据】

Trie的代码实现 import java.util.TreeMap;/*** Trie树(前缀树、字典树)** @author whx* @version 2018/9/1*/public class Trie {/*** 节点类** @author whx* @version 2018/9/1*/private class Node{public boolean isWord;publ

Leetcode171: Implement Trie (Prefix Tree)

Implement a trie with insert, search, and startsWith methods. Trie树又被称为字典树、前缀树,是一种用于快速检索的多叉树。Tried树可以利用字符串的公共前缀来节省存储空间。 但如果系统存在大量没有公共前缀的字符串,相应的Trie树将非常消耗内存。 Trie树的基本性质如下: 根节点不包括字符,除根节点外每个节点包括

秋招突击——算法练习——8/26——图论——200-岛屿数量、994-腐烂的橘子、207-课程表、208-实现Trie

文章目录 引言正文200-岛屿数量个人实现 994、腐烂的橘子个人实现参考实现 207、课程表个人实现参考实现 208、实现Trie前缀树个人实现参考实现 总结 引言 正文 200-岛屿数量 题目链接 个人实现 我靠,这道题居然是腾讯一面的类似题,那道题是计算最大的岛屿面积,如果当时没做出来,现在得哭死!好在做出来了!这道题单纯使用回溯实现的,然后修改一下地图的坐标

字典树(trie 树)

Trie树又称字典树,字典查找树。 Trie有三种结构:标准trie 压缩trie 后缀trie。本篇博文主要介绍标准trie 标准 Trie树的结构 : 所有含有公共前缀的字符串将挂在树中同一个结点下。实际上trie简明的存储了存在于串集合中的所有公共前缀。 假如有这样一个字符串集合X{bear,bell,bid,bull,buy,sell,stock,stop}。它的标准Trie树如下图

力扣题/图论/实现 Trie (前缀树)

实现 Trie (前缀树) 力扣原题 Trie(发音类似 “try”)或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补全和拼写检查。 请你实现 Trie 类: Trie() 初始化前缀树对象。 void insert(String word) 向前缀树中插入字符串 word 。 boolean search(Str