码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法通关村第十八关——回溯


    回溯很大感觉就是多重递归,在递归的题目中,例如斐波那契数列,只需要考虑当前情况以及他的子情况。而在回溯中,要进行很多次递归,并且要对条件进行处理。

    LeetCode257:给你一个二叉树的根节点root,按任意顺序,返回所有从根节点到叶子节点的路径。

    叶子节点是指没有子节点的节点。

    示例:
    输入:root=[1,2,3,nu11,5]
    输出:["1->2->5","1->3"]

    1. class BinaryTreePaths {
    2. List<String> ans = new ArrayList<>();
    3. public List<String> binaryTreePaths(TreeNode root) {
    4. dfs(root, new ArrayList<>());
    5. return ans;
    6. }
    7. private void dfs(TreeNode root, List<Integer> temp) {
    8. if (root == null) return;
    9. temp.add(root.val);
    10. // 如果是叶子节点记录结果
    11. if (root.left == null && root.right == null) {
    12. ans.add(getPathString(temp));
    13. }
    14. dfs(root.left, temp);
    15. dfs(root.right, temp);
    16. temp.remove(temp.size() - 1);
    17. }
    18. // 拼接结果
    19. private String getPathString(List<Integer> temp) {
    20. StringBuilder sb = new StringBuilder();
    21. sb.append(temp.get(0));
    22. for (int i = 1; i < temp.size(); i++) {
    23. sb.append("->").append(temp.get(i));
    24. }
    25. return sb.toString();
    26. }
    27. }

    进入dfs,将当前节点添加到temp列表中,如果是叶子节点,那说明当前分支已经处理完了,像结果列表中添加拼接后的temp列表。

    如果不是叶子节点,那么就遍历左子树,右子树,按照前序的顺序来回溯,注意在当前分支结束后,要将最下面的那个节点去掉。

  • 相关阅读:
    CPC客户端的安装教程
    java-net-php-python-ssm房产信息管理系统计算机毕业设计程序
    CTFshow,信息搜集:web4
    【MySQL进阶简写】
    基于SqlSugar的开发框架循序渐进介绍(27)-- 基于MongoDB的数据库操作整合
    一文带你上手自动化测试中的PO模式!
    云上攻防-云原生篇&K8s安全&Config泄漏&Etcd存储&Dashboard鉴权&Proxy暴露
    centos7磁盘挂载及目录扩容
    模仿抖音直播商城带货打赏功能做一个app系统
    初识面相对象深入理解、构造方法--学习JavaEE的day12
  • 原文地址:https://blog.csdn.net/m0_63975489/article/details/132653967
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号