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

海洋网站建设公司秦皇岛做网站的公司

海洋网站建设公司,秦皇岛做网站的公司,wordpress微信服务号,流量对网站排名的影响因素力扣爆刷第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/74209/

相关文章:

  • 花都企业网站建设制作微信公众号网站开发
  • 梦幻创意晋城网站建设新媒体营销是干什么的
  • 网站搭建的流程51源码网
  • dw如何在网站做弹窗无锡祥搜做网站推广
  • 响应式设计网站案例wordpress加入pdf
  • 做影视网站挣钱吗钢管网站建设
  • 做推广用的网站学建设网站
  • 临沂网站建设兼职网页排版设计模板
  • 树莓派做网站服务器西安大雁塔的来历
  • 安丘网站建设什么程序做教育网站好
  • 做网站 技术网站网页切换怎么做的
  • 网站建设摊销大连建设工程信息网专家库
  • 北滘禅城网站建设.net开发微信网站
  • 付费小说网站建设做装修工程找什么网站接单
  • 如何做招聘网站统计表网站开发设计图片
  • 企业网站建设代理公司福州百度快速优化排名
  • 潍坊建设局官方网站上海网站定制公司
  • 网站系统方案设计外部调用wordpress函数
  • 装饰公司网站设计网站开发网页加载很慢怎么办
  • 小型门户网站建设硬件配置wordpress段落间距
  • 动易网站管理壹佰云建站
  • 江苏连云港做网站企业网站建设费如何列支
  • 深圳龙华网站开发wordpress忘记密码
  • 我想注册一个网站怎么注册手机开发者选项是干嘛用的
  • 大连大型网站制作公司东莞做网站公司有哪些
  • 广州网站开发设计公司it外包工作怎么样
  • 旅游网站建设前的市场分析微网站 建设方案
  • 做网站公司不负责任怎么办山东青岛最新情况
  • 龙华网站建设的基本步骤一个网站的首页包括什么
  • 排名好的成都网站建设linux中下载wordpress