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

图书馆网站开发策划书科技公司名字大全

图书馆网站开发策划书,科技公司名字大全,python前端开发需要学哪些东西,站长工具seo综合查询全面解析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/102896/

相关文章:

  • 重庆商务网站建设成都app开发
  • 深圳平台网站开发黄山旅游网页设计作业
  • 纪检监察机关网站建设方案建设网站简单的需要多少天
  • 苏州建设教育协会网站可信的网站建设
  • 怎么做网站的思维导图软件工程师分类
  • 手机网站推广网站做数据分析的意义
  • 金融网站素材广州低价网站建设
  • 沈阳城市建设学院网站邹城住房城乡建设部网站
  • 鄂州正规网站建设app排版网站
  • 如何免费创建一个自己的网站如何查询网站点击率
  • 广州app制作优化型网站建设的基本要求
  • 江津做网站襄阳微信网站建设
  • 阿里云网站建设官方自营店wordpress 获取文章
  • 网站建设中图片尺寸自助网站模板平台
  • 平台型网站建设wordpress怎么用两个主题
  • 宁波建网站选哪家好点烟台公司网站建设
  • 做网站兰州产品毕业设计作品网站
  • 外贸电子商务网站如何进行网络推广市场定位
  • 东莞优化seo网站关键词优化腾网站建设
  • 出口网站制作个人网站怎么建立流程
  • 网站建设信(信科网络)微博优惠券网站怎么做
  • 苏州吴江建设局招标网站怎么开发网页
  • 新手建网站教程企业网站建设方案包含
  • 酒店 深圳 网站建设淘宝代运营公司哪家好
  • 网站架构模板广州白云学校网站建设
  • 网站公司市场营销方案全国企业信用信息查询公示系统
  • 右玉网站建设企业解决方案和应对措施
  • 盐山网站免费网站自动跳转
  • wordpress建站教程凌风网站建设项目分工
  • 部门网站建设管理报告做公司做网站有用吗