【每日一题】15.Xorto (前缀和枚举)
补题链接:Here
题意:选取任意不重叠的两个区间,使异或结果为 \(0\)
样例:\(1,2,3,4,5,5\)
在样例中我们可以选取 \(1,2,3\) 和 \(5,5\) 就是满足题意
思路:相同元素的异或为 \(0\) ,所以我们找到两个点 \(i - j\) ,与 \(i -j\) 相同答案的个数(这句话是废话....)
先求出异或前缀和,然后枚举每个位置,统计该位置之前的所有前缀和、即吧该位置作为右端点枚举计算右端点之前的所有位,为左端点计数。
同时当把该位当作右端点计算完之后,并用map存储,把该店当作左端点,逐个枚举右端点,用map查询相同的值,进行计数.
\(1,2,3,4,5,6,7,8,8\)
比如,当 \(i\) 运算到第一个 \(8\) 的时候,前面有 \(1,2,3\) 的异或值为 \(0\) ,且已经记录,然后当第一个 \(8\) 为右端点运算结束之后,变为左端点是,第一个 \(8\) 和第二个 \(8\) 异或结果为 \(0\) ,并且此时还有前面 \(1,2,3\) 异或为 \(0\) , \(累计数 +1\)
using ll    = long long;
const int N = 1e6 + 10;
ll n, x, ans, a[N], b[N];
void solve() {
    cin >> n;
    for (ll i = 1; i <= n; ++i) {
        cin >> x;
        a[i] = a[i - 1] ^ x;
    }
    for (ll i = 1; i <= n; ++i) {
        for (ll j = 0; j < i; ++j) b[a[i] ^ a[j]]++;
        for (ll j = i + 1; j <= n; ++j)
            ans += b[a[i] ^ a[j]];
    }
    cout << ans << "\n";
}
【每日一题】15.Xorto (前缀和枚举)的更多相关文章
- CISP/CISA 每日一题 15
		CISA 每日一题(答) 作业记帐: 监控和记录信息系统资源的使用,这些信息可被信息系统审计师用来执行: 1.将资源使用和相关用户挂钩以便实行计费: 2.通过改变系统软件的默认设置来最优化硬件性能 作 ... 
- 【python】Leetcode每日一题-前缀树(Trie)
		[python]Leetcode每日一题-前缀树(Trie) [题目描述] Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的 ... 
- [每日一题]面试官问:谈谈你对ES6的proxy的理解?
		[每日一题]面试官问:谈谈你对ES6的proxy的理解? 关注「松宝写代码」,精选好文,每日一题 作者:saucxs | songEagle 一.前言 2020.12.23 日刚立的 flag,每日一 ... 
- 【JavaScript】Leetcode每日一题-矩形区域不超过K的最大值和
		[JavaScript]Leetcode每日一题-矩形区域不超过K的最大值和 [题目描述] 给你一个 m x n 的矩阵 matrix 和一个整数 k ,找出并返回矩阵内部矩形区域的不超过 k 的最大 ... 
- 老男孩IT教育-每日一题汇总
		老男孩IT教育-每日一题汇总 第几天 第几周 日期 快速访问链接 第123天 第二十五周 2017年8月25日 出现Swap file….already exists以下错误如何解决? 第122天 2 ... 
- CISP/CISA 每日一题 五
		CISA 每日一题(答) 信息系统审计师要确认系统变更程序中的: 1.变更需求应有授权.优先排序及跟踪机制: 2.日常工作手册中,明确指出紧急变更程序: 3.变更控制程序应同时为用户及项目开发组认可: ... 
- 【JavaScript】Leetcode每日一题-在D天内送包裹的能力
		[JavaScript]Leetcode每日一题-在D天内送包裹的能力 [题目描述] 传送带上的包裹必须在 D 天内从一个港口运送到另一个港口. 传送带上的第 i 个包裹的重量为 weights[i] ... 
- 【JavaScript】Leetcode每日一题-平方数之和
		[JavaScript]Leetcode每日一题-平方数之和 [题目描述] 给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c . 示例1: 输入:c = 5 ... 
- 【JavaScript】Leetcode每日一题-二叉搜索树的范围和
		[JavaScript]Leetcode每日一题-二叉搜索树的范围和 [题目描述] 给定二叉搜索树的根结点 root,返回值位于范围 [low, high] 之间的所有结点的值的和. 示例1: 输入: ... 
- 【python】Leetcode每日一题-寻找旋转排序数组中的最小元素
		[python]Leetcode每日一题-寻找旋转排序数组中的最小元素 [题目描述] 已知一个长度为 n 的数组,预先按照升序排列,经由 1 到 n 次 旋转 后,得到输入数组.例如,原数组nums ... 
随机推荐
- css零散笔记——修改input样式input:-internal-autofill-selected背景色
			闲聊: 小颖项目中的登录页需将 input 背景色设为透明,小颖将 input 的背景色设置后,发现表单自动填充后还是会有背景色,然后发现 浏览器 自带了背景色: 效果图: ... 
- 畅捷通T+与道一云对接集成报销信息列表连通凭证创建
			畅捷通T+与道一云对接集成获取报销信息列表连通凭证创建 数据源系统:道一云 在道一云坚实的技术基础上,道一云推出全新升级的2.0产品矩阵,分别是低码平台.智能门户.场景应用.基于云原生底座,为企业提供 ... 
- Gson和fastJson应用场景
			如果有性能上面的要求可以使用Gson将bean转换json确保数据的正确,使用FastJson将Json转换Bean 二.Google的Gson包的使用简介. Gson类:解析json的最基础的工 ... 
- ubuntu 20.0.4 LTS 配置国内apt-get源
			https://blog.csdn.net/wangyijieonline/article/details/105360138 更换阿里源 要知道当前系统的代号,可以用以下命令: lsb_releas ... 
- 为什么说UUID是唯一的?
			在数字时代,我们需要一种能够唯一标识各种实体的方法.通用唯一标识符(UUID)正是为满足这一需求而诞生的.本文将从多个方面介绍UUID,探讨它为何成为通用唯一标识符,以及为什么说UUID是唯一的. U ... 
- Java 注解的实现原理
			注解的本质 在 java.lang.annotation.Annotation 接口中有这样的描述: The common interface extended by all annotation i ... 
- 《RAPL: A Relation-Aware Prototype Learning Approach for Few-Shot Document-Level Relation Extraction》阅读笔记
			代码 原文地址 预备知识: 1.什么是元学习(Meta Learning)? 元学习或者叫做"学会学习"(Learning to learn),它是要"学会如何学 ... 
- static、final、private是否可以修饰抽象方法?
			1.static和abstract:是不能共存的.static是为了方便调用,abstract是为了给子类重写,没有方法体. 2.final和abstract:是互相冲突的,final修饰的方法不能重 ... 
- 创建傀儡进程svchost.exe并注入DLL文件(Shellcode)
			本文主要利用 SetThreadContext 修改进程中的线程上下文来实现Dll注入(ShellCode). 实现原理 首先,使用 CreateProcess 函数创建svchost.exe进程,并 ... 
- Eclipse部署虚拟项目目录
			目录 1. 问题 2. 方案 3. 参考 1. 问题 对于一些附带了大量本地资源的项目(例如,用户上传的文件,地图切片或者三维模型等),在Eclipse中部署调试是我一直头痛的问题.因为Eclipse ... 
