代码随想录|Day25|回溯02|216.组合总和III、17.电话号码的字母组合

本文介绍了一个名为Solution的类中的组合总和III问题解决方案,使用了回溯算法并强调了剪枝在减少无效递归中的关键作用。通过示例解释了如何在满足特定条件时提前终止不必要的计算,提高算法效率。
摘要由CSDN通过智能技术生成

 216.组合总和III

class Solution(object):
   def combinationSum3(self, k, n):
      result = []
      self.backtracking(k, n, 0, 1, [], result)
      return result
   def backtracking(self, k, n, current_sum, start_index, path, result):
      if current_sum > n:   #剪枝
          return
      if len(path) == k:
         if current_sum == n:
            result.append(path[:])
         return
      for i in range(start_index, n-(k-len(path))+2):
         current_sum += i
         path.append(i)
         self.backtracking(k, n, current_sum, i+1, path, result)
         path.pop()
         current_sum -= i

【思考】 剪枝这一步很重要,是一个有效剪枝,比如n=4,k=3,当进行到1+2+3=6>4时,剪枝成功,不会再继续向下进行无效递归,会直接回到上一层开始探索1+3+。。。的组合。

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值