给定一棵二叉搜索树,请找出其中第k大的节点。
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
int res; //最后返回的第k大的节点
int num = 1; //当前第几大节点
public int kthLargest(TreeNode root, int k) {
dfs(root,k);
return res;
}
public void dfs(TreeNode root,int k){
if(root!=null){
dfs(root.right,k);
if(k==num++){
res = root.val;
return;
}
dfs(root.left,k);
}
}
}