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

专业做公司logo的网站新平台怎么推广

专业做公司logo的网站,新平台怎么推广,做服装外单的网站有哪些内容,做词频分析的网站文章目录 51 验证二叉搜索树52 二叉搜索树中第k小的元素53 二叉树的右视图54 二叉树展开为链表55 从前序与中序遍历序列构造二叉树 51 验证二叉搜索树 递归对二叉搜索树进行中序遍历,输出节点的值是单调递增的。方法1:对二叉树进行中序遍历,将…

文章目录

  • 51 验证二叉搜索树
  • 52 二叉搜索树中第k小的元素
  • 53 二叉树的右视图
  • 54 二叉树展开为链表
  • 55 从前序与中序遍历序列构造二叉树

51 验证二叉搜索树

在这里插入图片描述

  • 递归
  • 对二叉搜索树进行中序遍历,输出节点的值是单调递增的。
  • 方法1:对二叉树进行中序遍历,将节点的值放入数组中,判断数组是否单调递增(双指针)。
  • 方法2:maxval记录前一个节点的数值,初始化为一个绩效的值。
  • 方法3:新建节点pre,pre指向前一个结点,初始化为null。这里给出方法3的代码。
/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {TreeNode} root* @return {boolean}*/
var isValidBST = function(root) {let pre = new TreeNode();pre = null;var isValid = function(root) {if(root == null){ // 空树也是二叉搜索树return true;}let left = isValid(root.left);if(pre != null && pre.val >= root.val){return false;}pre = root;let right = isValid(root.right);return left && right;}return isValid(root);
};

52 二叉搜索树中第k小的元素

在这里插入图片描述

  • 递归
  • 求中序遍历的第k个节点。
  • 对二叉搜索树进行中序遍历,遍历到第k个节点时,记录结果res,记录结果后返回。
/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {TreeNode} root* @param {number} k* @return {number}*/
var kthSmallest = function(root, k) {var traversal = function(root){if(root == null){return;}traversal(root.left);if(k == 0){return;}if(--k == 0){res = root.val;}traversal(root.right);}let res = 0;traversal(root);return res;
};

53 二叉树的右视图

在这里插入图片描述

  • 递归
  • 先递归右子树,再递归左子树。
  • 每层设置一个深度deep,遍历过程中,若该节点对应层的deep首次访问,则将该节点存入右视图结果数组中。
/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {TreeNode} root* @return {number[]}*/
var rightSideView = function(root) {var traversal = function(root, deep){if(root == null){return;}if(deep == res.length){res.push(root.val);}traversal(root.right, deep + 1);traversal(root.left, deep + 1);}let deep = 0;let res = [];traversal(root, deep);return res;
};

54 二叉树展开为链表

在这里插入图片描述

  • 递归
  • 使用"倒"中序遍历,即右 -> 左 -> 中,遍历结果(654321)中的第一个节点就是链表的最后一个节点(6)。
  • 新建pre作为前一个结点,初始化为null,随着"倒"中序遍历不断为其赋值为前一个结点。
  • 除了最后一个节点的左节点不为null外,其他节点的左节点都为null,右节点都为pre。
/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {TreeNode} root* @return {void} Do not return anything, modify root in-place instead.*/
var flatten = function(root) {var traversal = function(root){if(root == null){return;}traversal(root.right);traversal(root.left);if(pre != null){root.right = pre;root.left = null;}pre = root;}let pre = new TreeNode();pre = null;traversal(root);return root;
};

55 从前序与中序遍历序列构造二叉树

在这里插入图片描述

  • 递归
  • 前序数组的第一个元素为节点元素,在中序数组中寻找该元素作为分割点index,分割出左中序数组和右中序数组。
  • index可以理解为,在中序数组中,索引为index的位置前有index个元素,而左前序数组和左中序数组的length应该相等(右同理),因此可以借助index分割前序数组。
  • 根据index分割前序数组,得到左前序数组和右前序数组。
  • 叶子节点直接返回该节点,不必将左、右节点设置为null。
  • 将左前序数组和右中序遍历继续遍历,右前序数组和右中序数组继续遍历。
/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {number[]} preorder* @param {number[]} inorder* @return {TreeNode}*/
var buildTree = function(preorder, inorder) {var traversal = function(preorder, inorder){if(preorder.length == 0){return null;}let nodevalue = preorder[0];let node = new TreeNode(nodevalue);if(preorder.length == 1){ // 叶子节点直接返回return node;}let index = inorder.findIndex(item => item == node.val);let inleft = inorder.slice(0, index);let inright = inorder.slice(index + 1, inorder.length);let preleft = preorder.slice(1, 1 + index);let preright = preorder.slice(1 + index, preorder.length);node.left = buildTree(preleft, inleft);node.right = buildTree(preright, inright);return node;        }return traversal(preorder, inorder);
};
http://www.hkea.cn/news/790419/

相关文章:

  • apk连接wordpress上海seo
  • 企业建网站租用服务器好还是买一个好石家庄网站关键词推广
  • wordpress文件解析外贸网站优化
  • 建设工程竣工备案网站百度保障中心人工电话
  • 韶关城乡建设部网站首页营销型网站建设策划书
  • 建设银行手机银行下载官方网站谷歌浏览器网页版入口在哪里
  • 网站建设 好域名注册信息
  • 公众号微网站建设认证哪个推广网站好
  • 爬取1024上传到wordpress蔡甸seo排名公司
  • 流感吃什么药更好seo的方法
  • 营销型网站建设市场seo黑帽技术有哪些
  • 扬中做网站的公司seo虚拟外链
  • 永川集团网站建设免费网站seo诊断
  • 国外 上海网站建设网络营销推广方式案例
  • 24手表网站网络技术推广服务
  • 鞍山网站制作推广游戏推广员判几年
  • 360如何做网站优化网页设计制作软件
  • 金华网站建设电话电商运营主要负责什么
  • 百度的官方网站游戏推广工作好做吗
  • 著名的深圳网站建设网页快照
  • 政务网站建设要求快速排名软件哪个好
  • 自己网站怎么做优化色盲和色弱的区别
  • 苏州建网站公司seo网络推广培训班
  • 福清市建设局网站石家庄学院
  • 找考卷做要去哪个网站中国国家培训网官网查询
  • 软件系统开发的大概步骤优化网站标题名词解释
  • 院校网站建设模板建站平台
  • 淘宝网站内搜索引擎优化怎么做广告推广平台网站有哪些
  • 大片播放网站国外免费推广网站有哪些
  • flash网站cms排名sem优化软件