LeetCode 1863. 找出所有子集的异或总和再求和

LeetCode 1863. 找出所有子集的异或总和再求和

🧩 题目描述

给定一个数组 nums,我们要找到所有子集的异或总和,并返回这些总和的累加值

  • 子集可以为空
  • 异或总和是所有元素逐位 XOR 的结果
  • 数组中元素唯一,长度最大为 12

示例:

输入: nums = 1,3 输出: 6 解释: 子集有 \[\], 1, 3, 1,3 异或值分别为 0, 1, 3, 1^3=2 总和为 0+1+3+2 = 6

python

复制

编辑

💡 解题思路

这道题的关键是遍历所有子集,然后计算它们的异或值并求和。由于数组最大长度是 12,最多只有 2^12 = 4096 个子集,因此我们可以放心使用回溯法(DFS)枚举所有可能。

🧾 算法核心:

  • index=0 开始,对每个元素有两种选择:选或不选
  • 通过递归实现所有子集的遍历
  • 每当遍历到终点时,就将当前子集的异或值加到答案里

🧪 代码实现(Python)

python 复制代码
class Solution:
    def subsetXORSum(self, nums: List[int]) -> int:
        def dfs(index, cur_xor):
            if index == len(nums):
                return cur_xor
            # 不选 nums[index]
            a = dfs(index + 1, cur_xor)
            # 选 nums[index]
            b = dfs(index + 1, cur_xor ^ nums[index])
            return a + b

        return dfs(0, 0)
✅ 复杂度分析
时间复杂度:O(2^n),n 是数组长度(最多 12)

空间复杂度:O(n),递归深度最多为 n

🏁 总结
这是一道典型的枚举所有子集的题目,思路清晰,适合练习 DFS 回溯。由于题目范围小,可以直接暴力解决。
相关推荐
青梅橘子皮6 分钟前
Linux---虚拟地址空间
linux·运维·算法
KaMeidebaby7 分钟前
卡梅德生物技术快报|酵母表达系统工程:裂殖酵母穿梭载体分子改造与载体构建技术总结
网络·人工智能·网络协议·tcp/ip·算法
HZ·湘怡10 分钟前
二叉树 1
数据结构·算法·二叉树·
吴可可12325 分钟前
AutoCAD 2024搭配C#开发最佳实践
算法
Stick_ZYZ40 分钟前
从 Prompt 到 Context Engineering:Agent 真正稳定的关键
大数据·人工智能·算法·ai·prompt
ZHW_AI课题组44 分钟前
使用Stable Diffusion v1.5文本引导与无分类器引导(CFG)算法实现条件生成图片
人工智能·python·算法·机器学习·stable diffusion
黎阳之光1 小时前
数字孪生赋能智慧油站建设|黎阳之光全场景可视化安防管控平台落地应用
大数据·物联网·算法·安全·数字孪生
cpp_25011 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
小雨下雨的雨1 小时前
鸿蒙PC用Electron框架 实现 房产交易系统核心算法深度解析
前端·javascript·算法·华为·electron·鸿蒙系统
CQU_JIAKE1 小时前
6.3[a]
算法