dfs专题9——找出所有子集的异或总和再求和

🔥近津薪荼: [个人主页] 🎬个人专栏: 《近津薪荼的算法日迹》 《Linux操作系统及网络基础知识分享》 《c++基础知识详解》 《c语言基础知识详解》 ✨不要物化,矮化,弱化,钝化自己,保持锋芒,不要停止学习 这个世界上只有两个人真正在注意着你 八岁的你,和八十岁的你, 他们此刻正在注视着你, 一个希望你 勇敢开始 ,一个希望你 不留遗憾


1.上期参考代码

cpp 复制代码
class Solution {
vector<int>path;
vector<vector<int>>ret;
public:
    vector<vector<int>> subsets(vector<int>& nums) {
        dfs(nums,0);
        return ret;
    }
///////////////////////////////////////////////法一决策树为有或无的二叉树
//     void dfs(vector<int>& nums,int pos)
//     {
////出口       
//         if(pos==nums.size())
//         {
//             ret.push_back(path);
//             return;
//         }
// //有
//         path.push_back(nums[pos]);
//         dfs(nums,pos+1);
//         path.pop_back();//恢复现场
// //没有
//         dfs(nums,pos+1);
        
//     }
                 //法二
        void dfs(vector<int>& nums,int pos)
        {
            ret.push_back(path);
            for(int i=pos;i<nums.size();i++)
            {
                path.push_back(nums[i]);
                dfs(nums,i+1);
                path.pop_back();
            }         
        }
};  

2.本期知识点导图

3.本期要讲解的题目是

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

要点:

  • 找子集
  • 求子集的异或总和
  • 求所有异或总和的总和

4.解题

本题思路就是先找到子集,然后求异或总和,再求异或总和的总和

有了上一题的基础,这道题就非常简单~

只需要在子集那道题的基础上,处理一些

细节

  • 本题要返回的是sum,创建一个全局变量sum替代之前的ret
  • 回溯的方法提示:利用异或的计算性质

本题是练习题,大家理应能自己独立做出来的~

5.下期要讲解的题目是:

全排列 II

6.嗟食

如果小编写的内容对佬有帮助,还请大佬点点三连加关注哦
佬的支持就是我前进的最大动力 ~

期待与佬的再次相遇~

相关推荐
xsyaaaan4 小时前
leetcode-hot100-双指针:283移动零-11盛最多水的容器-15三数之和-42接雨水
算法·leetcode
炽烈小老头7 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
一碗白开水一7 小时前
【工具相关】OpenClaw 配置使用飞书:打造智能飞书助手全流程指南(亲测有效,放心享用)
人工智能·深度学习·算法·飞书
仰泳的熊猫8 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
Tisfy8 小时前
LeetCode 1888.使二进制字符串字符交替的最少反转次数:前缀和O(1)
算法·leetcode·字符串·题解
滴滴答滴答答9 小时前
机考刷题之 9 LeetCode 503 下一个更大元素 II
算法·leetcode·职场和发展
飞Link9 小时前
梯度下降的优化算法中,动量算法和指数加权平均的区别对比
人工智能·深度学习·算法
啊哦呃咦唔鱼9 小时前
LeetCode hot100-15 三数之和
数据结构·算法·leetcode
_日拱一卒9 小时前
LeetCode(力扣):杨辉三角||
算法·leetcode·职场和发展
rqtz9 小时前
基于I2C总线的IMU-磁力计融合算法与数据共享
算法·iic·espidf·qmc5883p·icm42670p·imu磁力计融合