异或和之和

题目:

0异或和之和 - 蓝桥云课

异或和之和

题目描述

给定一个数组 Ai​,分别求其每个子段的异或和,并求出它们的和。或者说,对于每组满足 1≤L≤R≤n 的 L,R,求出数组中第 L 至第 R 个元素的异或和。然后输出每组 L,R 得到的结果加起来的值。

输入格式
  • 输入的第一行包含一个整数 n。
  • 第二行包含 n 个整数 Ai,相邻整数之间使用一个空格分隔。
输出格式
  • 输出一行包含一个整数表示答案。
样例输入
复制代码
5
1 2 3 4 5
样例输出
复制代码
39
评测用例规模与约定
  • 对于 30% 的评测用例,n≤300;
  • 对于 60% 的评测用例,n≤5000;
  • 对于所有评测用例,1≤n≤1e5,0≤Ai≤2的20次方。

思路:

如果暴力求,就需要三层循环,超时的,所以我们可以利用前缀和数组。为什么异或也可以呢,

prej 是 arr1 ^ arr2 ^ ... ^ arrj

prei-1 是 arr1 ^ arr2 ^ ... ^ arri-1

当我们计算 prej ^ prei-1 时,从arr1到arri-1的部分在两个前缀和中都存在,并且由于异或的自反性(a ^ a = 0),这些部分会被抵消掉,留下的就是arri到arrj的异或结果。

代码如下:

复制代码
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const ll N = 1e5+5;
ll n;
ll arr[N];
ll pre[N];
ll sum;
int main()
{
	cin >> n;
	for(ll i = 1 ; i <= n ; i++)
	{
		cin >> arr[i];
		pre[i] = pre[i-1] ^ arr[i];
	}
	for(ll i = 1 ; i <= n ; i++)
	{
		for(ll j = i ; j <= i ; j++)
		{
			sum += (pre[j] ^ pre[i-1]);		
		}
	}
	cout << sum;
	return 0;
}

O(n*n)肯定超时啊

优化2:

相关推荐
gCode Teacher 格码致知2 分钟前
Python教学:十六进制编码的显示方法-由Deepseek产生
开发语言·python·算法
05候补工程师2 分钟前
【408数据结构】核心考点:图(Graph)精炼笔记与算法直觉
数据结构·经验分享·笔记·考研·算法·图论
并不喜欢吃鱼2 分钟前
从零开始 C++------ 十四【C++ 数据结构】unordered_map/unordered_set 全解析:从使用到底层模拟实现
开发语言·数据结构·c++
靠沿3 分钟前
【动态规划算法】专题三——简单多状态dp问题
算法·动态规划
吃好睡好便好5 分钟前
矩阵秩的计算
人工智能·学习·线性代数·算法·机器学习·matlab·矩阵
计算机安禾7 分钟前
【算法分析与设计】第35篇:后缀数据结构:后缀树与后缀数组的构造
大数据·人工智能·算法·机器学习·剪枝
计算机安禾7 分钟前
【算法分析与设计】第38篇:最近点对与分治在几何中的应用
java·服务器·网络·数据库·算法
weixin_468466859 分钟前
深度学习损失函数新手实战指南
人工智能·python·深度学习·算法·机器学习·ai
yzq1991279 分钟前
语言在嵌入式系统中实现面向对象编程的实践与探索
算法
重生之我是Java开发战士10 分钟前
【贪心算法】整数替换,俄罗斯套娃信封问题,可被三整除的最大和,距离相等的条形码,重构字符串
算法·贪心算法