代码拉取完成,页面将自动刷新
同步操作将从 WuZe-wz/leetcode 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
import java.util.ArrayList;
import java.util.Arrays;
/**
* @author wuze
* @desc ...
* @date 2021-03-22 13:39:48
*/
public class 二叉搜索树的第k大节点_剑指offer_54 {
public class TreeNode {
int val;
TreeNode left;
TreeNode right;
TreeNode(int x) { val = x; }
}
/*
思路:
1、先遍历整颗树,将节点值都放在list里面
2、遍历list,加入数组arr(使用for循环)
3、对arr排序(Arrays.sort(arr);)
4、取出第k大元素(arr[arr.length-k];)
*/
class Solution {
/*
补充:
arr.length
arrayList.size()
str.length()
*/
public int kthLargest(TreeNode root, int k) {
ArrayList<Integer> list = new ArrayList<>();
dfs(root,list);
int arr[]= new int[list.size()];
for(int i=0;i<list.size();i++){
arr[i]=list.get(i);
}
Arrays.sort(arr);
return arr[arr.length-k];
}
void dfs(TreeNode root, ArrayList<Integer> list){
if(root==null){
return ;
}
//左中右 ==> 中序遍历
dfs(root.left,list);
list.add(root.val);
dfs(root.right,list);
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。