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

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

8个月前 (07-12)

力扣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)时间复杂度。关键在于理解异或运算的消去性质,以及如何将问题拆解为前缀统计。该思路可扩展至其他涉及区间异或和的场景,是算法设计中“状态转换”的经典应用。

原创内容 转载请注明出处

分享给朋友:

相关文章

CSP-J 2019纪念品题解(洛谷P5662):动态规划+完全背包问题的实战应用

CSP-J 2019纪念品题解(洛谷P5662):动态规划+完全背包问题的实战应用

一、题目解读2019年CSP-J的“纪念品”问题(对应洛谷P5662)要求玩家在T天内通过买卖纪念品最大化金币收益。每天可交易N种商品,需计算最优策略下的最终金币数。题目强调动态规划思维与资源分配优化...

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

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

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

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

一、题目解读2024年蓝桥杯省B组“传送阵”题目要求处理一个包含n个节点的图,节点间存在单向传输关系。每个节点i可传送至a[i]指定的节点,形成可能存在的环结构。题目需求解从任意节点出发能到达的最长路...

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

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

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

洛谷2789题解:直线交点数的递归求解与优化(附代码详解)

洛谷2789题解:直线交点数的递归求解与优化(附代码详解)

一、题目解读洛谷2789题要求计算n条直线在平面上两两相交时产生的不同交点数量。题目强调“不同”交点,需排除重复情况。解题关键在于如何高效枚举所有可能的交点组合,并避免重复计数。二、解题思路参考代码采...

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

一、题目解读牛客25461题要求计算一个花园中n朵花到两个喷泉的最小距离平方和。用户需输入喷泉坐标(x1,y1)和(x2,y2),以及n朵花的坐标(x,y),通过合理分配每朵花到两个喷泉的距离,使总距...

发表评论

访客

看不清,换一张

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