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

做公司网站需要多长时间seo顾问多少钱

做公司网站需要多长时间,seo顾问多少钱,邢台做网站哪儿好,我自己的网站力扣爆刷第142天之二叉树五连刷(构造树、搜索树) 文章目录 力扣爆刷第142天之二叉树五连刷(构造树、搜索树)一、106. 从中序与后序遍历序列构造二叉树二、654. 最大二叉树三、617. 合并二叉树四、700. 二叉搜索树中的搜索五、98. …

力扣爆刷第142天之二叉树五连刷(构造树、搜索树)

文章目录

      • 力扣爆刷第142天之二叉树五连刷(构造树、搜索树)
      • 一、106. 从中序与后序遍历序列构造二叉树
      • 二、654. 最大二叉树
      • 三、617. 合并二叉树
      • 四、700. 二叉搜索树中的搜索
      • 五、98. 验证二叉搜索树

一、106. 从中序与后序遍历序列构造二叉树

题目链接:https://leetcode.cn/problems/construct-binary-tree-from-inorder-and-postorder-traversal/description/
思路:首先把中序遍历的key和value用map记录下来,节省通过后序定位根节点的时间,然后不断的用父节点划分左右子数组。

class Solution {Map<Integer, Integer> map = new HashMap<>();public TreeNode buildTree(int[] inorder, int[] postorder) {for(int i = 0; i < inorder.length; i++) {map.put(inorder[i], i);}return traverse(inorder, postorder, 0, inorder.length-1, 0, postorder.length-1);}TreeNode traverse(int[] inorder, int[] postorder, int leftIn, int rightIn, int leftPo, int rightPo) {if(leftIn > rightIn) return null;int mid = map.get(postorder[rightPo]);TreeNode root = new TreeNode(postorder[rightPo]);root.left = traverse(inorder, postorder, leftIn, mid-1, leftPo, leftPo+mid-leftIn-1);root.right = traverse(inorder, postorder, mid+1, rightIn, leftPo+mid-leftIn, rightPo-1);return root;}}

二、654. 最大二叉树

题目链接:https://leetcode.cn/problems/maximum-binary-tree/description/
思路:也是前序遍历构建二叉树,在每一次指定区间的内,通过比较获取最大值,然后通过最大值划分左右子数组。

class Solution {public TreeNode constructMaximumBinaryTree(int[] nums) {return buildTree(nums, 0, nums.length-1);}TreeNode buildTree(int[] nums, int left, int right) {if(left > right) return null;int max = nums[left], mid = left;for(int i = left; i <= right; i++) {if(nums[i] > max) {max = nums[i];mid = i;}}TreeNode root = new TreeNode(max);root.left = buildTree(nums, left, mid-1);root.right = buildTree(nums, mid+1, right);return root;}
}

三、617. 合并二叉树

题目链接:https://leetcode.cn/problems/merge-two-binary-trees/description/
思路:合并二叉树,其实就是遍历其中一棵树,然后把另外一颗树连接到这棵树上。

class Solution {public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {if(root1 == null && root2 == null) {return null;}if(root1 == null) return root2;if(root2 == null) return root1;root1.val += root2.val;root1.left = mergeTrees(root1.left, root2.left);root1.right = mergeTrees(root1.right, root2.right);return root1;}}

四、700. 二叉搜索树中的搜索

题目链接:https://leetcode.cn/problems/search-in-a-binary-search-tree/description/
思路:利用二叉搜索树的特性,从上往下进行搜索,相等返回,小于去左子树,大于去右子树。

class Solution {public TreeNode searchBST(TreeNode root, int val) {if(root == null) return null;if(root.val == val) {return root;}else if(root.val > val) {return searchBST(root.left, val);}else{return searchBST(root.right, val);}}}

五、98. 验证二叉搜索树

题目链接:https://leetcode.cn/problems/validate-binary-search-tree/description/
思路:要想验证是不是二叉搜索树,直接利用二叉搜索树的特性,中序单调遍历递增,只要非单调递增即不是。

class Solution {boolean flag = true;TreeNode p = null;public boolean isValidBST(TreeNode root) {traverse(root);return flag;}void traverse(TreeNode root) {if(root == null) return ;traverse(root.left);if(p != null) {if(p.val >= root.val) {flag = false;return ;}}p = root;traverse(root.right);}
}
http://www.tj-hxxt.cn/news/114516.html

相关文章:

  • 安庆网站建设公司湖南网络推广机构
  • 积分商城seo排名平台
  • 学做ps的网站经典软文案例标题加内容
  • 中原郑州网站建设营销宣传方案
  • wordpress显示浏览数网络优化工程师有多累
  • iosapp做网站关键词seo深圳
  • 公共部门网站建设维护互联网平台推广
  • 广州网站建设正seo线下培训机构
  • 网站建设与应用域名查询
  • wordpress大气优化游戏卡顿的软件
  • 淘宝客网站制作视频教程销售方案怎么做
  • 优秀网站首页sem竞价托管代运营
  • 阿里有做网站网络营销的概念与含义
  • 龙华网站推广培训沧州网络推广外包公司
  • 用什么软件做网站hao网络销售怎么才能找到客户
  • WordPress如何设置站点名称百度网盘搜索引擎入口
  • 做管道方面的网站百度爱采购怎么优化排名
  • 网站空间就是主机吗郑州seo学校
  • 标题制作网站深圳做网站公司哪家好
  • 南京app开发外包公司谈谈你对seo概念的理解
  • dw怎么做网站的导航栏在百度上做广告推广要多少钱
  • 网站开发维护专员岗位职责免费seo关键词优化排名
  • 做网站排名赚钱吗青岛seo代理计费
  • 长沙网站制作案例天琥设计培训学校官网
  • 做微商那个网站好好用的推广平台
  • 有了php源码怎么做网站seo 工具分析
  • 中国建设银行假网站进一步优化营商环境
  • 辅助教学网站开发技术讨论希爱力5mg效果真实经历
  • 苏州市建设局老网站seo计费系统开发
  • 中国数学外国人做视频网站搜外seo视频 网络营销免费视频课程