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

中山网站代运营企业网站 批量备案

中山网站代运营,企业网站 批量备案,哈尔滨市工程信息网,徐州建设工程交易110.平衡二叉树 题目链接:110.平衡二叉树 文档讲讲:代码随想录 状态:还可以 思路:计算左右子树的深度差,递归判断左右子树是否符合平衡条件 题解: public boolean isBalanced(TreeNode root) {if (root n…

110.平衡二叉树

在这里插入图片描述

题目链接:110.平衡二叉树
文档讲讲:代码随想录
状态:还可以

思路:计算左右子树的深度差,递归判断左右子树是否符合平衡条件

题解:

    public boolean isBalanced(TreeNode root) {if (root == null) {return true;}int leftLen = getMaxLen(root.left);int rightLen = getMaxLen(root.right);return Math.abs(leftLen - rightLen) <= 1 && isBalanced(root.left) && isBalanced(root.right);}public int getMaxLen(TreeNode node) {if (node == null) {return 0;}int leftLen = getMaxLen(node.left);int rightLen = getMaxLen(node.right);return Math.max(leftLen, rightLen) + 1;}

257. 二叉树的所有路径

在这里插入图片描述

题目链接: 257. 二叉树的所有路径
文档讲解:代码随想录
状态:没写出来

思路:前序+回溯的思路,遇到叶子节点收集路径

递归解法:

    public List<String> binaryTreePaths(TreeNode root) {List<String> res = new LinkedList<>();StringBuilder sb = new StringBuilder();getPath(root, res, sb);return res;}public void getPath(TreeNode root, List<String> res, StringBuilder sb) {if (root == null) {return;}int length = sb.length();sb.append(root.val);if (root.left == null && root.right == null) {res.add(sb.toString());} else {sb.append("->");getPath(root.left, res, sb);getPath(root.right, res, sb);}sb.setLength(length); // 恢复StringBuilder的状态}

迭代解法:

    public List<String> binaryTreePaths(TreeNode root) {List<String> res = new LinkedList<>();if (root == null) {return res;}// 创建双端队列来存储节点和路径Deque<TreeNode> deque = new LinkedList<>();Deque<String> pathDeque = new LinkedList<>();// 初始节点和路径deque.addLast(root);pathDeque.addLast(Integer.toString(root.val));while (!deque.isEmpty()) {TreeNode node = deque.pollLast();String path = pathDeque.pollLast();// 如果当前节点是叶子节点,将路径添加到结果中if (node.left == null && node.right == null) {res.add(path);}// 如果右子节点不为空,添加到队列中并更新路径if (node.right != null) {deque.addLast(node.right);pathDeque.addLast(path + "->" + node.right.val);}// 如果左子节点不为空,添加到队列中并更新路径if (node.left != null) {deque.addLast(node.left);pathDeque.addLast(path + "->" + node.left.val);}}return res;}

404.左叶子之和

在这里插入图片描述

题目链接: 404.左叶子之和
文档讲解:代码随想录
状态:总觉得自己递归的思路对的,但是结果就是不对,原来是代码中笔误把root.left.right写成了root.right.right。。。。

递归题解:

    public int sumOfLeftLeaves(TreeNode root) {// 如果根节点为空,返回0if (root == null) {return 0;}// 检查当前节点的左子节点是否为叶子节点if (root.left != null && root.left.left == null && root.left.right == null) {// 如果左子节点是叶子节点,返回左叶子节点的值,加上左子树和右子树的左叶子节点值return root.left.val + sumOfLeftLeaves(root.left) + sumOfLeftLeaves(root.right);} else {// 如果左子节点不是叶子节点,递归遍历左子树和右子树return sumOfLeftLeaves(root.left) + sumOfLeftLeaves(root.right);}}

迭代题解:

    public int sumOfLeftLeaves(TreeNode root) {if (root == null) {return 0;}int sum = 0;Deque<TreeNode> deque = new LinkedList<>();deque.addLast(root);while (!deque.isEmpty()) {int size = deque.size();while (size-- > 0) {TreeNode node = deque.pollFirst();if (node.left != null) {if (node.left.left == null && node.left.right == null) {sum += node.left.val;}deque.addLast(node.left);}if (node.right != null) {deque.addLast(node.right);}}}return sum;}
http://www.yayakq.cn/news/808370/

相关文章:

  • 网站接入支付宝需要网站备案吗新媒体营销策划
  • 辉玲建设集团有限公司网站企业网站优化培训
  • 做化工的外贸网站都有什么意思云南省城乡住房与建设厅网站
  • 怎么做俄语网站wordpress首屏加载速度
  • 鄞州中学网站谁做的中国跨境电商出口平台
  • 房地产网站建设招商视觉差网站制作
  • 建立一个个人网站做网站建设小程序
  • 做选择网站网站备案用户名忘了怎么办
  • 温州网站定制网站制作与发布
  • 济南网络推广公司排名百度网站排名优化工具
  • 怎么把网站放到空间小程序原生开发
  • 搬瓦工可以长期做网站河北手机网站建设
  • 郑东新区建设局网站网站新闻列表页面代码
  • 成都程序员网站如何做好集团网站建设
  • 基于工作过程的商务网站建设 网页制作咨询网络服务商
  • 在什么网站可以接活做迅雷网站做爰视频
  • 企业网站可以自己做可以做渐变色块拼接的网站
  • 大庆免费网站建设新的数据新闻
  • 炫酷的html5网站有没有什么专门做兼职的网站
  • 广东网站建设电话咨询哈尔滨市建设工程信息网官方网站
  • 网站建设和风险评估深圳网站设计网站制作
  • 广西城乡住房建设厅网站成都公司注册地址
  • 网站左侧树形导航怎么做企业营销型网站策划
  • 做饮食找工作哪个网站好网站建设和注册
  • 淘宝客网站建设视频cad dwt模板做网站模版
  • 做图片网站用什么程序响应式网页设计与实现
  • 牛什么的网站建设wordpress转换成 dede
  • 企业网站托管企业网站建设在网络营销中的地位与作用
  • 重庆造价工程建设信息网站做网站的云服务器选什么
  • 在职考研哪个网站做的好ai智能写作一键生成