对pythonappend与浅拷贝的实例讲解-创新互联

在做Leetcode的第39题的时候,看到网上一个用递归的解法,很简洁。于是重写了一遍。

网站建设哪家好,找成都创新互联!专注于网页设计、网站建设、微信开发、微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了保山免费建站欢迎大家使用!
class Solution(object):
 def combinationSum(self, candidates, target):
 """
 :type candidates: List[int]
 :type target: int
 :rtype: List[List[int]]
 """
 result,temp = [],[]
 self.combinationSumRecu(sorted(candidates),result,0,temp,target)
 return result

 def combinationSumRecu(self, candidates, result, start, temp, target):
 if target == 0:
  result.append(temp) # 注意此处不能直接append(temp),否则是浅拷贝,之后temp.pop()时会将result中的数也pop出来
 while start < len(candidates) and candidates[start]<=target:
  temp.append(candidates[start])
  self.combinationSumRecu(candidates, result, start, temp,target-candidates[start])
  temp.pop()
  start += 1

if __name__ == '__main__':
 print Solution().combinationSum([2,3,6,7],7)

网站栏目:对pythonappend与浅拷贝的实例讲解-创新互联
文章分享:http://bzwzjz.com/article/diopjo.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 响应式网站设计 网站建设公司 成都网站建设 成都商城网站制作 成都网站设计 LED网站设计方案 成都网站建设推广 成都网站设计公司 网站制作 响应式网站设计方案 品牌网站建设 成都网站设计制作公司 手机网站建设套餐 企业网站建设 成都网站建设 成都定制网站建设 成都网站建设 成都响应式网站建设 成都响应式网站建设 阿坝网站设计 重庆网站建设 网站建设推广