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

网站域名icp 备案价格外链收录网站

网站域名icp 备案价格,外链收录网站,武汉网站建设需要多少钱,六安属于哪里跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的! 代码随想录 LeetCode:257. 二叉树的所有路径 给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根…

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录

LeetCode:257. 二叉树的所有路径
给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。
叶子节点 是指没有子节点的节点。
示例 1:
在这里插入图片描述
输入:root = [1,2,3,null,5]
输出:[“1->2->5”,“1->3”]
示例 2:
输入:root = [1]
输出:[“1”]

注意这里traversal函数里面path使用的是list,是引用传递的,需要回溯;前序遍历,中左右

	public List<String> binaryTreePaths(TreeNode root) {if (root == null)return new ArrayList<>();// 存放结果List<String> res = new ArrayList<>();// 存放当前的路径List<String> path = new ArrayList<>();traversal(root, path, res);return res;}private void traversal(TreeNode cur, List<String> path, List<String> res) {// 先将当前节点的val放入path中,这里不考虑NPE,非空的时候在调用该方法path.add(cur.val + "");// 如果当前节点是叶子节点if (cur.left == null && cur.right == null) {String temp = String.join("->", path);res.add(temp);}// 左子结点不为空才继续向左if (cur.left != null) {traversal(cur.left, path, res);// 这个remove就是回溯的过程!path.remove(path.size() - 1);}// 右子结点不为空才继续向右if (cur.right != null) {traversal(cur.right, path, res);path.remove(path.size() - 1);}}

和上面解法的区别就是初始的时候就往list里面放cur.val了,这样在traversal方法里面就仅剩:终止条件,单层递归逻辑(分别向左,右遍历),就是一个简单的前序遍历,中左右

	public List<String> binaryTreePaths(TreeNode root) {if (root == null)return new ArrayList<>();// 存放结果List<String> res = new ArrayList<>();// 存放当前的路径List<String> path = new ArrayList<>();path.add(root.val + "");traversal(root, path, res);return res;}private void traversal(TreeNode cur, List<String> path, List<String> res) {// 如果当前节点是叶子节点if (cur.left == null && cur.right == null) {String temp = String.join("->", path);res.add(temp);}// 左子结点不为空才继续向左if (cur.left != null) {path.add(cur.left.val + "");traversal(cur.left, path, res);// 这个remove就是回溯的过程!path.remove(path.size() - 1);}// 右子结点不为空才继续向右if (cur.right != null) {path.add(cur.right.val + "");traversal(cur.right, path, res);path.remove(path.size() - 1);}}

精简版,traversal方法参数中传的是字符串

	public List<String> binaryTreePaths(TreeNode root) {if (root == null)return new ArrayList<>();List<String> res = new ArrayList<>();traversal(root, "", res);return res;}private void traversal(TreeNode cur, String path, List<String> res) {path += cur.val;if (cur.left == null && cur.right == null) {res.add(path);}if (cur.left != null) {traversal(cur.left, path + "->", res);}if (cur.right != null) {traversal(cur.right, path + "->", res);}}
http://www.mmbaike.com/news/37614.html

相关文章:

  • wordpress的站点地图武汉百捷集团百度推广服务有限公司
  • 免费的游戏网站建设搜索引擎优化简历
  • 网站做系统叫什么名字东莞营销网站建设直播
  • 天津做网站建设公司为什么中国禁止谷歌浏览器
  • 网站制作眼什么是网络营销
  • php wordpress配置同仁seo排名优化培训
  • 目录 mac wordpress网络优化工程师骗局
  • 建电子商城网站黑帽seo技术论坛
  • 怎么用eclipse做网站开发seo专业培训中心
  • 牟平网站建设品牌推广活动有哪些
  • 搜索网站做推广百度高级搜索首页
  • 做网站什么都不懂 怎么做今日头条热点新闻
  • 电商网站建设与管理网络防御中心
  • 站酷设计师网站跨境电商平台
  • 临夏网站制作武汉百度推广外包
  • 数字孪生开发平台免费seo网站
  • 网站开发员工资怎么营销自己的产品
  • 住房城乡建设管理委员官方网站爱网站关键词挖掘
  • 成都网站设计最加科技买友情链接
  • 女人与黑狗做视频网站百度热搜排名
  • 长清做网站成都百度推广电话
  • 做海报的素材网站业务多平台怎么样
  • 免费做app网站网络营销的核心是
  • 网站建设如何测试厦门seo招聘
  • 商城建设网站公司北京优化靠谱的公司
  • 做技术网站赚钱吗国际重大新闻事件10条
  • 做网站的dreamweaver自己如何建立网站
  • 做策划的都上哪些网站搜索资料间站长工具使用
  • 做网站的流程方法十大销售管理软件排行榜
  • 做网站是如何实施的沈阳专业seo关键词优化