博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【LeetCode每天一题】Combination Sum(组合和)
阅读量:5813 次
发布时间:2019-06-18

本文共 1679 字,大约阅读时间需要 5 分钟。

Given a set of candidate numbers (candidates) (without duplicates) and a target number (target), find all unique combinations in candidates where the candidate numbers sums to target.The same repeated number may be chosen from candidates unlimited number of times.

Note:

  • All numbers (including target) will be positive integers.
  • The solution set must not contain duplicate combinations.

Example 1:

Input: candidates = [2,3,6,7] ,     target = 7,

A solution set is:[  [7],  [2,2,3]]

Example 2:

Input: candidates = [2,3,5],       target = 8A solution set is:[  [2,2,2,2],  [2,3,3],  [3,5]] 思路

对于在数组中进行组合查找这种类似的问题,我们可以使用递归来进行解决。因为其中同一个数字可以重复利用多次,所以对于递归的写法应该注意。解决思路主要看代码的注释。 解决代码

 
1 class Solution(object): 2     def combinationSum(self, nums, target): 3         """ 4         :type candidates: List[int] 5         :type target: int 6         :rtype: List[List[int]] 7         """ 8         if len(nums) < 1: # nums中数目小于1时直接返回 9             return []10         res = []             #  保存结果11         nums.sort()          # 排序之后可以减少递归次数12         self.get_res(nums, res, 0, [],target)    # 进行递归13         return res14     15     def get_res(self, nums, res, index, path, target):16         if target == 0:        # 递归结束条件,当target等于0时,表示满足。将结果集进行添加。17             return res.append(path)18         if target < 0:          # 递归结束条件,不满足直接进行返回。19             return 20         for i in range(index, len(nums)):      # 因为在数组中每一个数字可以多次重复利用,所以index表示从第几个元素开始进行执行。21             if target < nums[index]:         # 如果当前首元素大于target时,直接终止,避免不必要的递归22                 return23             self.get_res(nums, res, i, path+[nums[i]], target-nums[i])

 

 

转载于:https://www.cnblogs.com/GoodRnne/p/10695183.html

你可能感兴趣的文章
asp.net怎样在URL中使用中文、空格、特殊字符
查看>>
ISA2006实战系列之二:实战ISA三种客户端部署方案(下)
查看>>
Linux后门入侵检测工具,附bash漏洞最终解决方法
查看>>
ASA5585-S20测试方案
查看>>
利用for循环打印实心棱形和空心棱形
查看>>
路由器发布服务器
查看>>
实现跨交换机VLAN间的通信
查看>>
oracle import & export 操作相关脚本
查看>>
LVS集群的体系结构,构建强壮的体系结构里负载均衡层、真实服务器层、后端共享存储层都是相辅相成...
查看>>
VTK读取raw格式的数据
查看>>
java泛型
查看>>
J2EE搭建之十一 如何设置start-on-load
查看>>
像这样的高额授权费在业界并不常见
查看>>
我的友情链接
查看>>
推荐几本书
查看>>
批量实现多台服务器之间ssh无密码登录的相互信任关系
查看>>
mongodb中投票节点作用
查看>>
思科ACL详解
查看>>
mysql自动备份脚本及异地定时FTP
查看>>
使用Django开发一个图书管理系统------02-需求分析设计
查看>>