代码随想录 Day-30 回溯总结篇

回溯法理论基础

  1. 回溯是递归的副产品,有递归就会有回溯
  2. 回溯法就是暴力搜索
  3. 回溯法能解决(组合问题/排列问题/切割问题/子集问题/棋盘问题)
  4. 回溯三部曲:
    1)递归函数的返回值和参数
    2)确认终止条件
    3)单层搜索过程(可剪枝优化)
  5. 组合问题:
    1)一个集合来求组合,需要startIndex
    2)多个集合取组合,各个集合之间相互不影响,不用startIndex
    3)当集合元素会有重复,但要求解集不能包含重复的组合时,使用used数组来标记candidates是否使用过,当sort函数也起到了去重的作用
  6. 切割问题:
    1)大体思路等同于组合问题,但在字符串切割时,往往遍历完搜索过程,整个函数就结束了,因此不需要终止条件
  7. 排序问题:
    1)每一层都是从0开始,而不是从startIndex开始
    2)需要使用used数组记录path中放了哪些元素
    3)尽量不使用set函数,因为其去重效率比较低
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值