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

网站域名icp 备案价格seo自动优化软件下载

网站域名icp 备案价格,seo自动优化软件下载,杭州网站建设交易,小说网站80电子书怎么做跟着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.15wanjia.com/news/45042.html

相关文章:

  • 怎样创建官方网站微信营销平台系统
  • 嘉兴人才网英文网站seo
  • 包头学做网站网页设计欣赏
  • 绛帐做企业网站如何自己做一个网页
  • iis网站域名访问目前引流最好的平台
  • 做网站教程 简书nba今日数据
  • 做净化行业需要知道的网站国际购物网站平台有哪些
  • 计算机软件开发网站建设取什么名字百度竞价推广方案范文
  • wordpress适合视频网站吗微友圈推广平台怎么加入
  • app定制开发网站制作网址安全中心检测
  • 北京南站到北京西站在线网站流量查询
  • 广昌网站建设沈阳seo优化
  • 获取当前分类的父级wordpress青岛seo整站优化公司
  • wordpress幻灯片怎么建seo怎么做关键词排名
  • 广州网站建设 乐云seo惠州seo外包费用
  • 做网站一般链接什么数据库域名查询网站入口
  • 网站建设上传服务器步骤长尾词挖掘工具
  • 汨罗网站建设优化关键词软件
  • javaweb网站开发流程网站seo排名优化方法
  • 怎么查寻一个网站做的竞价市场调研方案
  • 一个网站建设初期的成本排名软件下载
  • 地方电商门户网站如何建设哈尔滨seo推广
  • 凡客陈年现状360优化大师app下载
  • 百度提交链接什么是搜索引擎优化的核心
  • 宁阳县住房和城乡建设局网站seo搜索引擎优化简历
  • 大型网站如何开发网页优化包括
  • 网站建设方案策划书ppt响应式网站模板的优势
  • 做网站静态和动态企业网站推广方法实验报告
  • 宜宾建设教育培训中心网站重庆seo点击工具
  • 广州哪里做公司网站号网络推广工具