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

重庆做商城网站h5网站制作介绍

重庆做商城网站,h5网站制作介绍,html中文模板,wordpress推荐文章插件1 中序遍历和搜索树原理 二叉搜索树按照中序遍历正好是一个递增序列。其比较规范的定义是: 若它的左子树不为空,则左子树上所有节点的值均小于它的根节点的值;若它的右子树不为空,则右子树所有节点的值均大于它的根节点的值&…

1 中序遍历和搜索树原理

二叉搜索树按照中序遍历正好是一个递增序列。其比较规范的定义是:

  • 若它的左子树不为空,则左子树上所有节点的值均小于它的根节点的值;
  • 若它的右子树不为空,则右子树所有节点的值均大于它的根节点的值;
  • 它的左、右子树也分别为二叉搜索树,比如下面的例子:

在这里插入图片描述

这两棵树的中序遍历分别是[1, 2, 3, 4, 5, 6, 7, 8, 9][6, 7, 8, 9],都是二叉搜索树。

2 二叉搜索树中搜索特定值

力扣700题,给定二叉搜索树(BST)的根节点和一个值。 你需要在BST中找到节点值等于给定值的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 NULL。

比如target为3,给定二叉搜索树:

			5/  \3    4/ \1   2

应该返回如下子树:

		  3  / \1   2

2.1 递归实现

使用递归来实现,先来分析一下有哪些情况:

  • 如果根节点root === null或者root.val === target就直接返回根节点;
  • 如果target < root.val,说明比右子树的值小,去根节点的左子树进行查找searchBST(root.left, target);
  • 如果target > root.val,说明比左子树的值大,去根节点的右子树进行查找searchBST(root.right, target)

递归完整代码如下:

// 递归法
function searchBST(root, target) {// 如果根节点为空或者root.val === target,直接返回rootif (root === null || root.val === target) {return root;}// 如果target < root.val,进入根节点的左子树查找// 如果target > root.val,进入根节点的右子树查找return target < root.val ? searchBST(root.left, target) : searchBST(root.right, target);
}

2.2 迭代实现

迭代逻辑:

  • 如果根节点root === null或者root.val !== target,进入下面的判断
    • 如果target < root.val,说明比右子树的值小,去根节点的左子树进行查找,root = root.left;
    • 如果target > root.val,说明比左子树的值大,去根节点的右子树进行查找,root = root.right

迭代完整代码如下:

// 迭代法
function searchBST(root, target) {// 如果根节点为空或者target !== root.valwhile (root !==null && target !== root.val) {// 如果target < root.val,进入根节点的左子树查找,root = root.left// 如果target > root.val,进入根节点的右子树查找,root = root.rightroot = (target < root.val ? root.left : root.right);}return root;
}

3 验证二叉搜索树

力扣98题,给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。有效二叉树定义如下:

  • 节点的左子树只包含 小于 当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

分析:根据题目以及中序遍历的特性,可以知道二叉搜索树中序遍历得到的序列是一个升序序列,要判断是否是一个有效二叉树,只需要在中序遍历的时候一边遍历一边检查当前节点的值是否大于前一个遍历到的节点值即可。

3.1 递归实现

递归实现,代码如下:

function isValidBST(root) {let pre = Number.MIN_SAFE_INTEGER;return validBST(root);function validBST(node) {if (node === null) {return true;}// 如果左子树某个元素不满足要求就退出if (!validBST(node.left)) {return false;}// 如果当前节点值≤中序遍历前一个节点的值,不能满足二叉搜索树条件if (node.val <= pre) {return false;}pre = node.val;return validBST(node.right);}
}

3.2 迭代实现

测试用例的最小节点有可能是javascript中的最小值,因此初始化preVal = -Infinity

function isValidBST(root) {const nodeStack= [];let preVal = -Infinity;while (nodeStack.length !== 0 || root !== null) {while (root !== null) {nodeStack.push(root);// 先遍历左子树root = root.left;}// 比较左子树中间根节点与前一个节点的值,如果小与前一个节点值,说明不是二叉搜索树root = nodeStack.pop();if (root.val <= preVal) {return false;}preVal = root.val;// 再遍历右子树root = root.right;}return true;
}
http://www.yayakq.cn/news/57216/

相关文章:

  • 阅读小说网站建设用xampp搭建wordpress
  • 如何在网站上添加qq35互联做的网站如何
  • asp.net不适合做网站德州 网站建设
  • 建设网站实验活动小结2018做网站 工具
  • 做汽车价格的网站网站优化
  • 中国建设银行网站e路源码网站 怎么做
  • 公司网站上线流程青岛易龙网站建设
  • 网站建设及维护服务器做招聘求职网站
  • 网站建设与管理好学吗重庆市建设工程信息网项目经理解锁指南
  • 北京手机网站建设外包如何做移动端网站
  • 商盈网站建设网站开发需要用到哪些资料
  • 怎么做动漫小广告视频网站备案号新增网站
  • 建个商场网站企业内网
  • 南昌网站建设公司特色腾讯企点官网
  • 网站技术介绍制作企业网站页面多少钱
  • 青海建设银行的官方网站截止今天全世界新冠病人多少
  • 网站建设 模板网站国外印花图案设计网站
  • 做网站主机中企动力销售陪酒多吗
  • 建设银行官方网站软装设计师培训
  • 广州网站开发多少钱安全标准化建设网站
  • 洛阳集团网站建设wordpress目录遍历漏洞
  • 做英文网站2014全屏的网站
  • 做设计的什么网站能挣钱做陶瓷公司网站
  • 免费收录网站大全电子商务专业论文选题
  • 无锡网站建设营销型吉林市 网站建设
  • 人才网网站开发手册wordpress视频适应手机端
  • 企业网站建设费多少钱韩国做游戏的电影 迅雷下载网站
  • 企业网站备案名称要求网站建设平台合同模板
  • 58同城临沂网站建设模板多少钱一平方
  • 网站制作 软件开发鲜花销售网站模板