java quickselect_java 实现 快速查找算法 QuickSelect,

public class QuickSelect {

private static Comparable median3(Comparable[] data , int left, int right){

int center = (left + right) /2 ;

if(data[center].compareTo(data[left]) < 0)

swapReferences(data, left, center);

if(data[right].compareTo(data[left]) < 0)

swapReferences(data, left, right);

if(data[right].compareTo(data[center]) < 0)

swapReferences(data, center, right);

swapReferences(data, center, right -1);

return data[right - 1];

}

private static void swapReferences(Comparable[] data, int src, int des){

Comparable tmp;

tmp = data[des];

data[des] = data[src];

data[src] = tmp;

}

private static void quickSelect(Comparable[] data, int left, int right, int k){

if(left + CUTOFF <= right){

Comparable pivot = median3(data, left, right);

int i = left;

int j= right -1;

for(; ;){

while(data[++i].compareTo(pivot) < 0){}

while(data[--j].compareTo(pivot) > 0) {}

if(i < j)

swapReferences(data, i, j);

else

break;

}

swapReferences(data, i, right - 1);

if(k <= i){

quickSelect(data,left, i - 1, k);

//return data[left+k-1];

}

else{

quickSelect(data, i + 1, right, k);

//return data[left + k -1];

}

}

else{

insertionSort(data, left, right);

//return data[left + k -1];

}

}

private static void insertionSort(Comparable[] data, int left, int right){

int j;

for(int p = left + 1; p <= right; p++){

Comparable tmp = data[p];

for(j = p; j > left && tmp.compareTo(data[j-1]) < 0; j--)

data[j] = data[j-1];

data[j] = tmp;

}

}

public static Comparable quickSelect(Comparable[] data, int k){

quickSelect(data, 0, data.length - 1, k);

return data[k -1];

}

public static void main(String[] args){

Comparable[] a = new Comparable[20];

for(int i = 0; i < a.length; i ++)

a[i] = (int) (Math.random() * 100);

for(int i = 0; i < a.length; i ++)

System.out.print(a[i] + ", ");

System.out.println("//");

Comparable b = quickSelect(a, 8);

for(int i = 0; i< a.length; i++)

System.out.print(a[i] +", ");

System.out.println("//");

System.out.println(b);

}

private final static int CUTOFF = 10;

}

5, 8, 37, 72, 67, 64, 60, 32, 0, 95, 43, 3, 7, 16, 11, 75, 29, 54, 41, 13, //

5, 8, 11, 7, 3, 0, 13, 16, 29, 32, 43, 67, 72, 60, 37, 75, 64, 54, 41, 95, //

16

0

0

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2009-05-12 16:43

浏览 8947

评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值