穷举vs暴搜vs深搜vs回溯vs剪枝系列一>找出所有子集的异或总和再求和

题目:


解析:


代码:

java 复制代码
private int ret;//返回周结果
    private int path;//枚举一个元素就异或进去
    public int subsetXORSum(int[] nums) {
        dfs(nums, 0);
        return ret;
    } 

    private void dfs(int[] nums, int pos){
        ret += path;
        for(int i = pos; i < nums.length; i++){
            path ^= nums[i];
            dfs(nums,i+1);
            //相同为0消除掉相同元素达到回复现场效果
            path ^= nums[i];
        }
    }
相关推荐
橘颂TA22 分钟前
【剑斩OFFER】算法的暴力美学——只出现一次的数字 ||
算法·leetcode·动态规划
想唱rap1 小时前
C++ map和set
linux·运维·服务器·开发语言·c++·算法
小欣加油3 小时前
leetcode 1018 可被5整除的二进制前缀
数据结构·c++·算法·leetcode·职场和发展
WWZZ20253 小时前
快速上手大模型:深度学习12(目标检测、语义分割、序列模型)
深度学习·算法·目标检测·计算机视觉·机器人·大模型·具身智能
Andrew_Ryan4 小时前
llama.cpp Build Instructions
算法
玖剹4 小时前
递归练习题(四)
c语言·数据结构·c++·算法·leetcode·深度优先·深度优先遍历
做人不要太理性4 小时前
【Linux系统】线程的同步与互斥:核心原理、锁机制与实战代码
linux·服务器·算法
向阳逐梦4 小时前
DC-DC Buck 电路(降压转换器)全面解析
人工智能·算法
Mz12214 小时前
day04 小美的区间删除
数据结构·算法