当前位置:首页 > 力扣 > 力扣2588题解:利用前缀异或和与哈希表求解美丽子数组问题

力扣2588题解:利用前缀异或和与哈希表求解美丽子数组问题

5天前

力扣2588题解:利用前缀异或和与哈希表求解美丽子数组问题 力扣题解 前缀和 异或 哈希表 动态规划 C++ 第1张

一、题目解读

力扣2588题要求计算给定数组中“美丽子数组”的数量。所谓“美丽子数组”,是指子数组的异或和为0。题目关键在于理解子数组异或和的性质,并通过高效算法统计符合条件的子数组数量。

二、解题思路

采用“前缀异或和+哈希表”的巧妙思路。核心思想是:若两个前缀异或和相同,则中间子数组的异或和必为0(因为异或满足消去律)。通过维护前缀异或和的哈希表,统计每个前缀值出现的次数,即可快速计算出符合条件的子数组数。

三、解题步骤

1. 初始化:创建哈希表记录前缀异或和出现次数,将初始值0的出现次数设为1。

2. 遍历数组:计算当前前缀异或和,若哈希表中存在该值,说明存在子数组异或和为0,累加对应次数。

3. 更新哈希表:将当前前缀异或和的出现次数+1。

4. 返回结果:累计所有符合条件的子数组数量。

四、代码与注释

class Solution {
public:
    long long beautifulSubarrays(vector<int>& nums) {
        unordered_map<int, int> prefix_xor_counts; // 存储前缀异或和及其出现次数
        prefix_xor_counts[0] = 1; // 初始前缀异或和为0出现1次(空子数组)
        
        int current_xor = 0; // 当前前缀异或和
        long long result = 0; // 结果计数器
        
        for (int num : nums) {
            current_xor ^= num; // 计算当前前缀异或和
            result += prefix_xor_counts[current_xor]; // 若存在相同前缀异或和,累加子数组数
            prefix_xor_counts[current_xor]++; // 更新当前值的出现次数
        }
        
        return result;
    }
};

五、总结

本解法通过前缀异或和将子数组问题转化为前缀计数问题,利用哈希表实现O(n)时间复杂度。关键在于理解异或运算的消去性质,以及如何将问题拆解为前缀统计。该思路可扩展至其他涉及区间异或和的场景,是算法设计中“状态转换”的经典应用。

原创内容 转载请注明出处

分享给朋友:

相关文章

力扣654:递归分治的艺术 如何用最大元素构建二叉树

力扣654:递归分治的艺术 如何用最大元素构建二叉树

题目重解我们面对一个看似简单却充满递归魅力的题目:给定一个不含重复元素的整数数组,需要构建一棵特殊的二叉树。这个树的每个父节点都必须是当前子数组中的最大元素,而它的左右子树则分别由该最大值左侧和右侧的...

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

题目重解想象你是一名药师,有t分钟在山上采集m种草药。每种草药需要time分钟采集,价值为num。这就像考试时分配时间做题,要选择收益最大的题目组合。题目要求计算在规定时间内能获得的最大草药价值。解题...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

手搓顺序表类代码注释与详解:从零实现动态数组(新手教程)

一、简介和特点顺序表(Sequential List)是数据结构中基础的一种线性表,其特点是将数据元素存储在连续的内存空间中。通过数组实现,支持随机访问(即通过索引直接访问元素),适用于频繁随机读取的...

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

一、题目解读题目要求在一个n×m的网格中,从左上角到右下角选择一条路径,路径上的数字可重复取用,求取数之和的最大值。路径限制为仅能向右或向下移动。需注意路径的灵活性与重复取数的可能性,传统单向动态规划...

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

一、题目解读LeetCode 120题“三角形最小路径和”要求给定一个由数字组成的三角形,从顶部开始向下移动,每次可向左或向右移动一格,计算从顶至底的最小路径和。三角形以二维向量形式给出,每层元素数量...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。