当前位置: 首页 > news >正文

回溯算法--总结1

第一周总结

  1. 回溯问题抽象为树形结构,可以直观的看出其搜索的过程:for循环横向遍历,递归纵向遍历,回溯不断调整结果集。
  2. 回溯算法三部曲:
    1. 参数。
    2. 终止条件。
    3. 单层递归逻辑。
  3. 剪枝:
    1. 剪枝1:for循环在寻找起点的时候要有一个范围,如果这个起点到集合终止之间的元素已经不够 题目要求的k个元素了,就没有必要搜索了。
    2. 剪枝2:在求和问题中,排序之后加剪枝是常见的套路!
    3. 比如组合中要求有四个元素,从1-9中选择,当遍历到6时就没必要继续递归了。因为往后不够四个元素。
  4. startIndex:
    1. 一般只有一个集合求组合问题时候,使用startIndex,并且能保证组合中的元素不重复。
    2. 有多个集合从中求组合问题时,不需要使用startIndx,比如电话号码的字母组合。
    3. 注意以上说的是求组合的情况,如果是排列问题,又是另一套分析的套路,后面我在讲解排列的时候会重点介绍

第二周总结

  1. “树枝去重”和“树层去重”
    1. 在candidates[i] == candidates[i - 1]相同的情况下:
      • used[i - 1] == true,说明同一树枝candidates[i - 1]使用过
      • used[i - 1] == false,说明同一树层candidates[i - 1]使用过
  2. 切割问题(分割回文串)
    1. 切割问题其实类似组合问题
    2. 如何模拟那些切割线:startIndex模拟切割线
    3. 切割问题中递归如何终止
    4. 在递归循环中如何截取子串
  3. 子集问题
    1. 在树形结构中子集问题是要收集所有节点的结果,而组合问题是收集叶子节点的结果
http://www.cnnetsun.cn/news/113236.html

相关文章:

  • 零基础学网安不慌!电脑小白 4 阶段入门路线,分阶段学习不踩坑
  • 传统锁 vs Redisson分布式锁:效率对比实测
  • 封神!从开发转安全渗透工程师,这是我做的最对的职业选择
  • 3、循环与分支:编程中的核心逻辑控制
  • 小白必看:5分钟学会检查你的个人信息是否泄露
  • 效率对比:传统开发vs使用MyBatisPlus代码生成器
  • DeepSeek在线:5分钟打造你的AI应用原型
  • EVS9323-EP伺服变频器
  • AI市场舆情分析榜,原圈科技领跑车企
  • 1900-0711-81触摸屏面板
  • 深圳比亚迪游学|被Zhong国智造狠狠圈粉!新能源黑科技太炸了[特殊字符]✨
  • 小程序项目之捷邻小程序源码(java+ssm+小程序+mysql)
  • 如何用AI技术自动检测个人数据泄漏风险
  • DDoS攻击入门:小白也能懂的防护指南
  • Qwen是“源神”?实际上GLM-4.6才是被低估的黑马
  • 5分钟搭建js for in原型
  • Java毕设选题推荐:基于JavaWeb的汽车租赁系统的设计与实现基于Javaweb的租车管理系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Redis客户端工具在电商系统中的应用实战
  • 9.数据结构哈夫曼树期末考试速览
  • 对比:传统vs AI方法解决npm证书问题的效率差异
  • 基于遗传算法优化最小二乘支持向量机(GA-LSSVM)的跨验证多输出数据回归预测MATLAB代...
  • 小白必看:什么是Socket端口冲突?如何简单解决?
  • 防火洁净室窗技术选型要点与适配标准讲解
  • 效率翻倍:Win10截图快捷键的隐藏技巧大全
  • 企业级DDoS防护实战:从攻击分析到应急响应
  • 基于CEEMDAN-PE-LSTM模型的复杂时间序列预测算法与优化探讨
  • 5分钟搭建TLS兼容性测试原型
  • MySQL启动图解指南:小白也能懂的5步操作
  • Notepad++新手必知的10个实用技巧
  • 电商后台API模拟实战:用json-server搭建原型系统