首页 > 其他 > 详细

编程之美 2.5

时间:2018-04-13 13:53:00      阅读:178      评论:0      收藏:0      [点我收藏+]

解法1:利用分治法,先将某个数排在正确得位置,即比他大的数在左边,比他小的数在右边。然后比较他及他后面的数与k的大小。

import java.util.*;
public class Main{
    public static void main(String[] args) {
        int[] nums={10,3,2,9,8,5,7,6,20,1};
        int k=5;
        int[] res=new int[k];
        int len=nums.length;
        res=deepFun(nums,0,len-1,k);
        for(int i=0;i<5;i++){
            System.out.println(res[i]);
        }
        
    }
    public static int[] deepFun(int[] nums,int start,int end,int k){
        int temp=nums[start];
        int left=start;
        int right=end;
        while(left<right){
            while(left<right && nums[right]<=temp){
                right--;
            }
            if(left<right){
                nums[left]=nums[right];
                nums[right]=temp;
            }
            while(left<right && nums[left]>=temp){
                left++;
            }
            if(left<right){
                nums[right]=nums[left];
                nums[left]=temp;
            }
        }
        int[] res=new int[k];
        if(left-start+1==k){
            System.arraycopy(nums,start,res,0,k);
        }else if(left-start+1>k){
            res=deepFun(nums,start,left,k);
        }else{
            System.arraycopy(nums,start,res,0,left-start+1);
            int[] next=deepFun(nums,left+1,end,k-left+start-1);
            System.arraycopy(next,0,res,left-start+1,k-left+start-1);
        }
        return res;
    }
}

 

编程之美 2.5

原文:https://www.cnblogs.com/xinyi-blog/p/8819878.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!