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

做帮助手册的网站平面设计

做帮助手册的网站,平面设计,如何搭建自己的微信小程序商城,朝阳住房和城乡建设厅网站题目描述 给定一棵二叉搜索树,请找出其中第 k 大的节点。 解题基本知识 二叉搜索树(Binary Search Tree)又名二叉查找树、二叉排序树。它是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子…

题目描述

给定一棵二叉搜索树,请找出其中第 k 大的节点。

在这里插入图片描述

解题基本知识

二叉搜索树(Binary Search Tree)又名二叉查找树、二叉排序树。它是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。

  • 解法一: 递归

    利用二叉搜索树的特性进行中序遍历。先遍历左节点,然后根节点,最后遍历右节点,得到的是一个递增序列,那么序列的倒序为递减序列。因此这道题我们可以转变为求二叉搜索树中序遍历倒序的第 k 个数。
    在这里插入图片描述

    /*** Definition for a binary tree node.* function TreeNode(val) {*     this.val = val;*     this.left = this.right = null;* }*/
    /*** @param {TreeNode} root* @param {number} k* @return {number}*/
    const kthLargest = (root, k) => {let res = null; // 初始化返回值// 因为需要倒序第 k 个,所以处理是右节点,根节点,然后左节点const dfs = (root) => {if (!root) return; // 如果当前节点为 null,本轮处理结束dfs(root.right); // 开始处理右节点if (k === 0) return; // k 值 为 0,代表已经处理的节点超过目标节点,本轮处理结束if (--k === 0) {// 当 k 值 减 1 为 0,表示已经到了我们想要的 k 大 节点,保存当前值res = root.val;}dfs(root.left); // 处理左节点};dfs(root); // 从初始化节点开始处理return res;
    };
    
    • 复杂度分析:
      • 时间复杂度 O(N):无论 k 的值大小,递归深度都为 N,占用 O(N) 时间。
      • 空间复杂度 O(N):无论 k 的值大小,递归深度都为 N,占用 O(N) 空间。
  • 解法二: 迭代
    思路还是二叉树的中序遍历,利用栈的方式进行遍历。
    在这里插入图片描述

    /*** Definition for a binary tree node.* function TreeNode(val) {*     this.val = val;*     this.left = this.right = null;* }*/
    /*** @param {TreeNode} root* @param {number} k* @return {number}*/
    var kthLargest = function (root, k) {if (!root) return 0;// 声明储存栈const stack = [];// 判断当前栈否有节点和当前遍历节点位置while (stack.length || root) {while (root) {// 往栈里添加当前节点,同时切换为右节点处理stack.push(root);root = root.right;}// 取出当前栈顶元素,根据添加的顺序,当前元素是栈内最大的const cur = stack.pop();k--;if (k === 0) return cur.val;// 切换为左节点处理root = cur.left;}return 0;
    };
    
    • 复杂度分析:
      • 时间复杂度 O(N):需要遍历整棵树一次,复杂度为 O(N)
      • 空间复杂度 O(N):需要额外空间栈进行储存树,复杂度为 O(N)
http://www.mmbaike.com/news/42267.html

相关文章:

  • 兰州市生态建设管理局网站域名ip地址在线查询
  • 做幼儿网站的目标外贸推广建站
  • 宝山网站建设中国去中心化搜索引擎
  • 动易企业网站网络营销方式与工具有哪些
  • 龙华网站建设设计宁波seo怎么做推广渠道
  • 外贸移动端网站模板西安企业网站seo
  • 做快三网站谷歌seo网站运营
  • com网站注册合肥网络营销公司
  • 网站开发下人员配置软件开发流程八个步骤
  • 手机app软件开发公司排名上海搜索引擎优化1
  • 学做ps的软件的网站有哪些内容百度网址大全电脑版旧版本
  • 电子工程师网站中国新闻
  • 哪些网站做的人比较少最近三天的新闻大事国内
  • 北京网站建设公司排行每日新闻摘要30条
  • 安居客网站应该如何做app软件下载站seo教程
  • unity做网站竞价排名点击
  • 如何选择盐城网站开发跨境电商seo什么意思
  • 南通做网站企业旅游最新资讯 新闻
  • 安徽省建设工程资料上传网站最新的销售平台
  • 山东网站优化公司黑帽seo培训
  • 国外b站免费版长春百度推广公司
  • 邵阳网站建设多少钱网络推广和竞价怎么做
  • 增加网站备案杭州seo公司排名
  • 自己做的网站添加交费功能谷歌优化技巧
  • 学校网站制作公司企业网站seo服务
  • 转做批发鞋子的网站太原seo排名收费
  • 广东快速做网站公司游戏推广引流
  • 满山红厦门网站建设嘉兴seo外包服务商
  • 中国建设银行陕西分行官方网站互联网广告是做什么的
  • 用C语言做网站登录界面自己怎么做一个网页