码迷,mamicode.com
首页 > 其他好文 > 详细

#215. Kth Largest Element in an Array

时间:2017-11-01 19:38:05      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:div   tor   n+1   pivot   log   element   size   begin   and   

class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        return findInner(nums, 0, nums.size()-1,k);
    }
    
    
    int findInner(vector<int>& nums, int iLeft,int iRight,int k){
        if(iRight == iLeft)  return nums[iLeft];
        int idx = rand()%(iRight - iLeft + 1) + iLeft;
        int pivot = nums[idx];
        nums[idx] = nums[iLeft];
        int iBegin = iLeft;
        int iEnd = iRight;
        
        while (iBegin < iEnd) {
               while (iBegin < iEnd && nums[iEnd] <= pivot) {
                     iEnd--;
               }
               nums[iBegin] = nums[iEnd];
               while (iBegin < iEnd && nums[iBegin] >= pivot) {
                     iBegin++;
               }
               nums[iEnd] = nums[iBegin];
        }
        nums[iBegin] = pivot; //iBegin == iEnd

        //divide and  conquer
        int iLeftPartNum = iBegin - iLeft;
        if(iLeftPartNum == k - 1)
               return nums[iBegin];
        else if(iLeftPartNum > k - 1){
              return findInner( nums, iLeft,iBegin-1, k);
        }
        else if(iLeftPartNum < k - 1){
              return findInner( nums,iBegin+1, iRight, k-(iLeftPartNum+1));
        }
        
        
        
    }
};

  

#215. Kth Largest Element in an Array

标签:div   tor   n+1   pivot   log   element   size   begin   and   

原文地址:http://www.cnblogs.com/dongfangchun/p/7767950.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!