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

塘沽做网站烟台网站建设公司地址

塘沽做网站,烟台网站建设公司地址,百度推广软件,建设进出口外贸网站力扣爆刷第116天之CodeTop100五连刷66-70 文章目录 力扣爆刷第116天之CodeTop100五连刷66-70一、144. 二叉树的前序遍历二、543. 二叉树的直径三、98. 验证二叉搜索树四、470. 用 Rand7() 实现 Rand10()五、64. 最小路径和 一、144. 二叉树的前序遍历 题目链接:htt…

力扣爆刷第116天之CodeTop100五连刷66-70

文章目录

      • 力扣爆刷第116天之CodeTop100五连刷66-70
      • 一、144. 二叉树的前序遍历
      • 二、543. 二叉树的直径
      • 三、98. 验证二叉搜索树
      • 四、470. 用 Rand7() 实现 Rand10()
      • 五、64. 最小路径和

一、144. 二叉树的前序遍历

题目链接:https://leetcode.cn/problems/binary-tree-preorder-traversal/description/
思路:前序遍历什么可以说的,在进入左右子树前收集节点。

class Solution {List<Integer> list = new ArrayList<>();public List<Integer> preorderTraversal(TreeNode root) {if(root == null) return list;list.add(root.val);preorderTraversal(root.left);preorderTraversal(root.right);return list;}
}

二、543. 二叉树的直径

题目链接:https://leetcode.cn/problems/diameter-of-binary-tree/description/
思路:求直径其实就是求某个节点的左子树深度与右子树深度,连接成的一个向上的尖括号,理解了这个关系,就直接像求深度一样,后序遍历,求左右子树深度,记录最大值即可。

class Solution {int max = -1;public int diameterOfBinaryTree(TreeNode root) {traverse(root);return max;}int traverse(TreeNode root) {if(root == null) return 0;int left = traverse(root.left);int right = traverse(root.right);max = Math.max(max, left + right);return Math.max(left, right) + 1;}
}

三、98. 验证二叉搜索树

题目链接:https://leetcode.cn/problems/validate-binary-search-tree/description/
思路:直接中序遍历,用一个变量记录前一个节点,然后中序遍历比较,如果不是,直接早停返回。

class Solution {boolean flag = true;TreeNode pro = null;public boolean isValidBST(TreeNode root) {traverse(root);return flag;}void traverse(TreeNode root) {if(root == null || !flag) return;traverse(root.left);if(pro != null) {if(pro.val >= root.val) {flag = false;return;} }pro = root;traverse(root.right);}
}

四、470. 用 Rand7() 实现 Rand10()

题目链接:https://leetcode.cn/problems/implement-rand10-using-rand7/description/
思路:可以采用概率组合,我们可以先用rand7构造出来一个p=0.2,再构造出来一个p=0.5,这两个事件构成一个事件的概率为p=0.1正好可以达到要求,例如先随机出来一个1-6的数,奇数偶数出现的概率为0.5,范围只要是偶数就行,然后我们再随机出来一个1-5的数,因为我们只放出来1-5,就相当于袋子里只有5个数,那每种数出现的概率就为0.2,然后组合到一块,判断第一个数是奇数还是偶数,通过这个返回1-5或者6-10。就相当于0.5*0.2;

class Solution extends SolBase {public int rand10() {int first, second;while((first = rand7()) > 6) ;while((second = rand7()) > 5) ;return (first & 1) == 1 ? second : 5 + second;}
}

五、64. 最小路径和

题目链接:https://leetcode.cn/problems/minimum-path-sum/description/
思路:定义dp[i][j]表示抵达grid[i][j]时的最短路径,由于只能从上和左的方向推出,则dp[i][j]=grid[i][j]+dp[i-1][j-1],如果要压缩到一维,也是可以的,注意初始化。

class Solution {public int minPathSum(int[][] grid) {int m = grid.length, n = grid[0].length;int[] dp = new int[n+1];Arrays.fill(dp, Integer.MAX_VALUE);for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {int t = Math.min(dp[j+1], dp[j]);t = t == Integer.MAX_VALUE ? 0 : t;dp[j+1] = grid[i][j] + t;}}return dp[n];}
}
http://www.yayakq.cn/news/325334/

相关文章:

  • 合肥网站关键词wordpress电影下载站
  • 如何将网站做的更美观vi视觉设计手册
  • 验证网站所有权wordpress分类链接打不开
  • 通桥小学的网站建设学做网站要多久多少钱
  • 蛇口网站建设桂林生活网手机版
  • 商城网站建设课设免费的关键词挖掘工具
  • 做网站网页的工作怎么样如何进行关键词分析
  • 网站备案后需要年检吗网站模板免费下载酒店管理系统
  • 网站开发需要多少钱如何胶州做淘宝的网站
  • 山东阳信建设局网站建设网站的基本知识
  • 哪个网站可以做魔方图片大全网站地图对seo
  • 本地58同城招聘网珠海百度搜索排名优化
  • 建设个人网站的好处怎么介绍网站的优缺点
  • 东莞网站建设17建设教育协会官网
  • 傻瓜网站开发软件网站域名邮箱怎么注册
  • 网站推广文案网站怎么接入百度地图
  • 天津市建设工程网站dw作业模板免费
  • 秦皇岛酒店网站设计wordpress与dede哪个好用
  • 网站被墙查询做儿童成长相册模版网站
  • 上海网站建设费用陕西做天然气公司网站
  • python用于网站开发现在还有什么推广渠道
  • wordpress怎么改标题荥阳网站优化公司
  • 文档分享类网站建设好大夫 网站开发
  • 江苏建设工程招标网官方网站福州销售网站设计企业
  • 阿里云发布网站网站开发付款方式和比例
  • 长春人文学院广州知名网站排名优化
  • 芗城网站建设公司成都平台公司
  • 招远网站建设招聘网站域名管理规范
  • 自助建站系统凡科阿里云上的网站建设
  • 织梦婚纱网站模板网站内容发布平台源码