zoukankan      html  css  js  c++  java
  • Kth Largest Element in an Array 解答

    Question

    Find the kth largest element in an unsorted array. Note that it is the kth largest element in the sorted order, not the kth distinct element.

    For example,
    Given [3,2,1,5,6,4] and k = 2, return 5.

    Note: 
    You may assume k is always valid, 1 ≤ k ≤ array's length.

    Solution 1 -- PriorityQueue

    1. 将所有元素放入heap中

    2. 依次用poll()取出heap中最大值

     1 public class Solution {
     2     public int findKthLargest(int[] nums, int k) {
     3         if (nums == null || k > nums.length)
     4             return 0;
     5         int length = nums.length, index = length - k, result = 0;
     6         PriorityQueue<Integer> pq = new PriorityQueue<Integer>(length,
     7                                                             new Comparator<Integer>(){
     8                                                                 public int compare(Integer a, Integer b) {
     9                                                                     return (a - b);
    10                                                                 }
    11                                                             });
    12         for (int i = 0; i < length; i++)
    13             pq.add(nums[i]);
    14         while (index >= 0) {
    15             result = pq.poll();
    16             index--;
    17         }
    18         return result;
    19     }
    20 }

    Improvement

     1 public class Solution {
     2     public int findKthLargest(int[] nums, int k) {
     3         if (nums == null || k > nums.length)
     4             return 0;
     5         int length = nums.length, index = k, result = 0;
     6         PriorityQueue<Integer> pq = new PriorityQueue<Integer>(length, Collections.reverseOrder());
     7         for (int i = 0; i < length; i++)
     8             pq.add(nums[i]);
     9         while (index > 0) {
    10             result = pq.poll();
    11             index--;
    12         }
    13         return result;
    14     }
    15 }

    Solution 2 -- Quick Select

    Quick Sort in Java

    Average Time O(n)

     1 '''
     2 a: [3, 2, 5, 1], 2
     3 output: 2
     4 '''
     5 
     6 def swap(a, index1, index2):
     7     if index1 >= index2:
     8         return
     9     tmp = a[index1]
    10     a[index1] = a[index2]
    11     a[index2] = tmp
    12 
    13 def partition(a, start, end):
    14     ''' a[start:end]
    15         pivot: a[end]
    16         return: index of pivot
    17     '''
    18     pivot = a[end]
    19     cur_big = start - 1
    20     for i in range(start, end):
    21         if a[i] >= pivot:
    22             cur_big += 1
    23             swap(a, cur_big, i)
    24     cur_big += 1
    25     swap(a, cur_big, end)
    26     return cur_big
    27 
    28 
    29 def quick_select(a, k):
    30     k -= 1
    31     length = len(a)
    32     start = 0
    33     end = length - 1
    34     while start < end:
    35         index = partition(a, start, end)
    36         if index == k:
    37             return a[index]
    38         if index > k:
    39             # Note: end != index
    40             end = index - 1
    41         else:
    42             # Note: start != index
    43             start = index + 1
    44             k = k - index
    45     return -1
    46 
    47 a = [3, 2, 5, 1]
    48 k = 1
    49 print(quick_select(a, k))
  • 相关阅读:
    Winform中怎样设置ContextMenuStrip右键菜单的选项ToolStripMenuItem添加照片
    JavaScript垃圾回收机制
    前端如何处理内存泄漏
    前端缓存
    深入理解vue-router之keep-alive
    (淘宝无限适配)手机端rem布局详解
    mysql不会使用索引,导致全表扫描情况
    MYSQL性能优化的最佳20+条经验
    深拷贝与浅拷贝的区别,实现深拷贝的几种方法
    vue组件通信方式总结
  • 原文地址:https://www.cnblogs.com/ireneyanglan/p/4827845.html
Copyright © 2011-2022 走看看