代码随想录训练营Day24回溯算法Part01|理论基础|77.组合问题

理论基础

  • 是递归的副产品,回溯法 == 回溯搜索法,是本质为穷举的纯暴力搜索法(可以加剪枝)
  • 可以解决的问题:
    • 组合问题,N个数里面按一定规则找出k个数的集合
    • 切割问题,一个字符串按一定规律有几种切割方式
    • 子集问题,一个N个数的集合里有多少中符合条件的子集
    • 排列问题,N个数按一定规则全排列,有几种排列方式
    • 棋盘问题,N皇后,解数独
    • PS:组合不强调元素顺序,排列强调元素顺序
  • 如何理解回溯法:
    • 画图理解,抽象为树形结构
    • 数的宽度(for遍历)–>集合大小;
    • 树的深度(递归遍历)–>
    • 函数:
      void backtracking(参数),参数很多,可能要一边写一边确定
    • 终止条件:
      if(终止条件){
          //在叶子节点收集结果
          return;
      }    
      
    • 单层搜索逻辑
      	for(集合的元素集){
      	//处理节点
      	backtracking(参数)//递归函数
      	//回溯操作,撤销处理节点
      }
      

77.组合

  • 照着模板很好写,递归+回溯
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值