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

淘宝网站小视频怎么做京东网站建设设计框架图

淘宝网站小视频怎么做,京东网站建设设计框架图,成都网站平面设计,网站建设方案怎么做题目: 给定一棵二叉搜索树,请找出其中第 k 大的节点的值。 示例 1: 输入: root [3,1,4,null,2], k 13/ \1 4\2 输出: 4 示例 2: 输入: root [5,3,6,2,4,null,null,1], k 35/ \3 6/ \2 4/1 输出: 4 限制: 1 ≤ k ≤ 二叉搜索树…

题目:

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

示例 1:

输入: root = [3,1,4,null,2], k = 13/ \1   4\2
输出: 4

示例 2:

输入: root = [5,3,6,2,4,null,null,1], k = 35/ \3   6/ \2   4/1
输出: 4

限制:

  • 1 ≤ k ≤ 二叉搜索树元素个数

-------------------------------------------------------------------------------------------------------------------------------

分析:

           二叉搜索树的特点就是根左<根<根右,所以我们经过思考可知,通过中序遍历(左中右),得到的是二叉搜索树值的升序。

           因为我们要得到第K大的结点值,所以我们要值的降序排列,那么我们就用逆中序遍历(右中左),根据k值来记录当前是第几个结点。

代码:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode(int x) { val = x; }* }*/
class Solution {int count,res;public int kthLargest(TreeNode root, int k) {this.count = k;method(root);return res;}public void method(TreeNode root) {if(root==null) return;if(count == 0) return;method(root.right);count--;if(count==0) {res = root.val;}method(root.left);}
}

因为进入递归之后记录数据k很乱,所以我们定义两个类变量count(用来记录当前是第几个结点)和res(用来存储第K大的值)。

思考:

之前我总是想不通为什么method(root.right);调用后要count-- 表示这个结点已经被遍历。

那method(root.left); 后面为什么不count-- 呢?

后来我想通了,我能提出这个问题说明我没懂递归的真谛。这个count--不是method(root.right);的count--。而是root的count-- 说明root这个结点被遍历到了。

递归整体可以这么理解,你就想先遍历一个结点(不带递归)

    public void method(TreeNode root) {if(root==null) return;if(count == 0) return;count--;if(count==0) {res = root.val;}}

当我把递归删掉后,我的目的就是遍历一个结点。

但是当我有遍历需求后,我想先看右边的,再遍历左边的。那么我就直接上下加个递归。

即:

    public void method(TreeNode root) {if(root==null) return;if(count == 0) return;method(root.right);count--;if(count==0) {res = root.val;}method(root.left);}

你可以将复杂的逻辑改成打印一个结点,那么我想先打印左再中再右。那么就上下加递归函数就可以了。

void method(TreeNode root) {if(root == null) return;method(root.left); //左System.out.println(root.val); //打印method(root.right); //右
}

就是这样。

http://www.yayakq.cn/news/588419/

相关文章:

  • 优秀的门户网站合肥一浪网络科技有限公司
  • 任丘市网站建设价格网站热度查询
  • 一起做网站广州哔哩哔哩网站建设分析
  • 天津北辰做网站情感导师在线咨询服务
  • 潍坊企化网站建设专业美工设计网站建设
  • 上海浦东医院网站建设承德教育信息网官网
  • 网站域名需要申请搜索引擎关键词怎么选
  • 网站页面分析范文wordpress 文章列表样式
  • 太原网站建设外包别人发我网站外链会降权我吗
  • 门户网站建设运行环境要求企业咨询服务合同
  • 在线做带字头像的网站wordpress列表图片
  • 做网站对商家的好处网站为什么要备案
  • 西安建站之家网络科技有限公司承包工地的网站
  • 南通市建设监理协会网站刚刚建设的网站如何放图片
  • 工会网站建设管理工作总结珠海网站建设公司怎么样
  • 做基网站人才市场招聘网站
  • 企业网站制作托管推荐优秀的企业网站设计
  • 校园网站素材wordpress advantage
  • 网站建设岗位能力评估表无锡手机网站
  • 淘宝上做进出口网站有哪些制作属于自己的网站
  • 网站留言板块怎么做做特价的网站
  • 兰州网站seo按天计费王占山人物简介
  • 百度有做企业网站吗一个正版ps软件多少钱
  • 网站快速备案价格做宣传的网站
  • 门户网站制作平台惠州公众号开发公司
  • 网站设计的原则网站建设公司方案
  • 汕头网站开发定制做视频的素材什么网站好
  • 网站流程网站开发人员 把网站注销
  • 赤峰城乡建设局网站学网站建设要多久
  • 玛纳斯县住房和城乡建设局网站wordpress4.4.1