LeetCode 39. 组合总和

class Solution {
public:
    vector<vector<int>> res;
    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        dfs(candidates,0,target);
        return res;
    }
    vector<int> path;
    void dfs(vector<int>& candidates,int u,int target)//枚举每个数字选几个
    {
        if(target==0||u==candidates.size())
        {
            if(!target) res.push_back(path);
            return;
        }
        for(int i=0;i*candidates[u]<=target;i++)
        {
            dfs(candidates,u+1,target-i*candidates[u]);
            path.push_back(candidates[u]);
        }
        for(int i=0;i*candidates[u]<=target;i++)    path.pop_back();
            
    }
};
posted @   穿过雾的阴霾  阅读(6)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示