标签:count TreeNode Offer int 54 二叉 max null root
题目:
给定一棵二叉搜索树,请找出其中第k大的节点。
示例 1:
输入: root = [3,1,4,null,2], k = 1 3 / \ 1 4 \ 2 输出: 4
示例 2:
输入: root = [5,3,6,2,4,null,null,1], k = 3 5 / \ 3 6 / \ 2 4 / 1 输出: 4
限制:
1 ≤ k ≤ 二叉搜索树元素个数
代码:
1 /** 2 * Definition for a binary tree node. 3 * public class TreeNode { 4 * int val; 5 * TreeNode left; 6 * TreeNode right; 7 * TreeNode(int x) { val = x; } 8 * } 9 */ 10 class Solution { 11 static int count=0; 12 static int res=0; 13 public int kthLargest(TreeNode root, int k) { 14 count=0; 15 max_k(root,k); 16 return res; 17 } 18 public static void max_k(TreeNode root,int k){ 19 //考察第k大的,先进右子树,第k小的,进左子树先 count!=k,条件时避免已经找到还继续递归下去 20 if(count!=k&&root.right!=null){ 21 max_k(root.right,k); 22 } 23 //判断当前结点是否时第k大 24 if(count!=k){ 25 count++; 26 if(count==k){ 27 res=root.val; 28 } 29 } 30 31 if(count!=k&&root.left!=null){ 32 max_k(root.left,k); 33 } 34 35 36 } 37 }
标签:count,TreeNode,Offer,int,54,二叉,max,null,root 来源: https://www.cnblogs.com/SEU-ZCY/p/14641974.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。