java 寻找数组中第k大的值
来源:互联网 发布:手机免费炒股软件 编辑:程序博客网 时间:2024/05/22 06:29
转载自 黄朝辉的博客
0.前言
在未排序的数组中查找第k大的数。这里不对k的值进行判断了,认为它是合法的。
1.排序
public static int findKthLargest(int[] nums, int k) { Arrays.sort(nums); return nums[nums.length - k];}
时间复杂度为O(nlog(n))。
2.通过堆
public static int findKthLargest(int[] nums, int k) { PriorityQueue<Integer> q = new PriorityQueue<Integer>(k); for (int i : nums) { q.offer(i); if (q.size() > k) { q.poll(); } } return q.peek();}
时间复杂度为O(nlog(k)),空间复杂度为 O(k) 。
3.快排
public static int findKthLargest(int[] nums, int k) { if (k < 1 || nums == null) { return 0; } return getKth(nums.length - k + 1, nums, 0, nums.length - 1);}public static int getKth(int k, int[] nums, int start, int end) { int pivot = nums[end]; int left = start; int right = end; while (true) { while (nums[left] < pivot && left < right) { left++; } while (nums[right] >= pivot && right > left) { right--; } if (left == right) { break; } swap(nums, left, right); } swap(nums, left, end); if (k == left + 1) { return pivot; } else if (k < left + 1) { return getKth(k, nums, start, left - 1); } else { return getKth(k, nums, left + 1, end); }}public static void swap(int[] nums, int n1, int n2) { int tmp = nums[n1]; nums[n1] = nums[n2]; nums[n2] = tmp;}
平均时间复杂度为O(n),最坏情况下为O(n^2)。
阅读全文
0 0
- java 寻找数组中第k大的值
- java 寻找数组中第k大的值
- java 寻找数组中第k大的值
- 寻找数组第k大的值
- 两个有序数组中,寻找第K大的数
- 寻找数组中第k大的数
- 寻找无序数组中第k大的数
- 寻找数组中第k大的数
- 寻找数组中的第K大的元素&找数组中重复数字
- leetcode | Median of Two Sorted Arrays 寻找2个有序数组中第k大的值
- 20170927_快排应用_数组中寻找第K大的数字
- 寻找无序数组中第k大的数——快排思想
- 第k大(小)数,寻找最小的k个数(进一步要求顺序与原数组中元素顺序一致)
- 寻找数列中第K大的数
- 数组中第K大的元素
- 数组中第k大的数
- 数组中第K大的数
- 数组中第K大的数
- Java Bean登录页面实现
- C++静态成员函数访问非静态成员的几种方法
- 2017.08.26 360笔试题:小明卖粉笔
- Linux下配置NDK、JDK环境变量
- zzuli2183—分步打表
- java 寻找数组中第k大的值
- 内核对象(2)之跨越边界进程共享内核对象
- spring data jpa懒加载session失效:OpenEntityManagerInViewFilter 取代OpenSessionInViewFilter
- KeyError: ‘SQLALCHEMY_TRACK_MODIFICATIONS’ 的错误问题
- maven webapp的标准pom.xml配置
- 零
- numpy 多个随机整数生成
- 8月英语总结
- Oracle LOB