146.组合总和

java 复制代码
class Solution {
    List<List<Integer>> res=new ArrayList<>();
    List<Integer> li=new ArrayList<>();
    public List<List<Integer>> combinationSum(int[] candidates, int target) {
        solut(candidates,target,0,0);
        return res;
    }
    void solut(int[] candidates, int target,int index,int listSum){
        if(listSum==target){
            res.add(new ArrayList<>(li));
            return;
        }
        for(int i=index;i<candidates.length&&listSum<=target;i++){
            li.add(candidates[i]);
            listSum+=candidates[i];
            solut(candidates,target,i,listSum);
            listSum-=li.get(li.size()-1);
            li.remove(li.size()-1);
        }
    }
}
python 复制代码
class Solution(object):
    def combinationSum(self, candidates, target):
        res=[]
        li=[]
        def solut(candidates,target,index,listSum):
            if listSum>target:
                return
            if listSum==target:
                res.append(li[:])
                return
            for i in range(index,len(candidates)):
                li.append(candidates[i])
                listSum+=candidates[i]
                solut(candidates,target,i,listSum)
                listSum-=li.pop()
        solut(candidates,target,0,0)
        return res
相关推荐
我是神62 分钟前
Pycharm无法预览md文件(已解决)
ide·python·pycharm·markdown
steamedobun9 分钟前
【爬虫】selenium打开浏览器以及页面
开发语言·python·selenium
智慧老师9 分钟前
数据结构第一弹-数据结构在不同领域的应用
开发语言·数据结构·python
dz88i81 小时前
关于Idea中database按钮不显示的问题
java·ide·intellij-idea
C灿灿数模1 小时前
2023和2024历年美赛数学建模赛题,算法模型分析!
算法·数学建模
zi__you2 小时前
【Python网络爬虫 常见问题汇总】
开发语言·爬虫·python
lshzdq2 小时前
【机器人】控制之稳定性判定: 李雅普诺夫Lyapunov (2) 如何设计李(李雅普诺夫)函数
线性代数·算法·机器人
水w2 小时前
微服务之间的相互调用的几种常见实现方式对比 2
java·开发语言·后端·微服务·架构
梧桐树04292 小时前
python面向对象高级编程:使用@property
开发语言·python
martian6652 小时前
深入详解人工智能机器学习常见算法——线性回归算法
人工智能·算法·机器学习·线性回归