public class MidSort {
public static void main(String[] args){
int[] arr={,,,,,,,,};
midSort(arr,,);
for(int i:arr){
System.out.print(i + " ");
}
System.out.println();
} //返回数组被中值分成两堆后中值所在位置
public static int partition(int[] goal,int left,int right,int midPos){//left和right是为位置指示,表明你要排序的是
// 数组的那部分,否则要把待排序的数组切割出来
int mid=goal[midPos];
int tmp,idx;
//把中值移到数组末尾
tmp=goal[right];
goal[right]=goal[midPos];
goal[midPos]=tmp; int smallPos=left;//指向比中值小的,每当有比中值小的数把它放入smallPos所指地方,然后smallPos+1,这样保证
//smallPos指过的位置都放着比中值小的(也就是在最前面的那些)
for(idx=left;idx<right;idx++){
if(goal[idx]<mid){//每当有比中值小的数把它放入smallPos所指地方,从而把小于中值的移到前面去
tmp=goal[idx];
goal[idx]=goal[smallPos];
goal[smallPos]=tmp;
smallPos++;
}
}
//把中值放回它应该在的位置
tmp=goal[right];
goal[right]=goal[smallPos];
goal[smallPos]=tmp;
return smallPos;//返回中值所在位置
} //因为选值来作为中值是随机的(有时是以第一个来作为),所以被分成两堆的数组可能不均衡,所有找出第k(此时k=(length+1)/2)
// 便使分堆后的数组平衡了)大的元素的位置
public static int selectKth(int[] goal,int left,int right, int k){//返回第K大元素
int midPos=selectMidPos(goal,left,right);//返回作为中值的为元素的位置,若是选数组第一个作为中值时有时会让性能
//退化成O(n的平方)(如它是最大、小值时,分堆后会有一堆为空),要避免
//会在数组中随机选一个作为中值
int pos=partition(goal,left,right,midPos);//数组被中值分成两堆后中值所在位置
if(pos==k+left-){//说明真正想要作为分堆的中值恰好就是之前选定分堆的中值
return pos;
}else if(k+left-<pos){//小于,如k是第4大,之前是第3大,所以小于,继续分堆直到返回k为止因为此时数组才按k作为中值来分堆
//所以第K大元素在在之前分好堆中的左边那堆,它在这堆是第k-pos大
return selectKth(goal,left,pos-,k);
}else{//大于,所以第K大元素在在之前分好堆中的右边那堆,它在这堆是第k大
return selectKth(goal,pos+,right,k-(pos-left+));
}
} public static void midSort(int[] goal,int left,int right){
if (left>=right)return;//如果只有一个元素或更少
int mid=(right-left+)/;
int midPos=selectKth(goal,left,right,mid+);//得到能把数组分为平均两堆的中值的位置且此时已分好堆
midSort(goal,left,left+mid-); //对左边这堆继续分堆
midSort(goal,left+mid+,right); //对右边这堆继续分堆
} public static int selectMidPos(int[] goal,int left,int right){
//随机选定中值
int distant =right-left+;
int random=(int)Math.round(Math.random()*distant);
int pos=random+left<=right?random+left:random+left-;
return pos; } }

中值排序的java实现的更多相关文章

  1. opencv-11-中值滤波及自适应中值滤波

    开始之前 在上一篇我们实现了读取噪声图像, 然后 进行三种形式的均值滤波得到结果, 由于我们自己写的均值滤波未作边缘处理, 所以效果有一定的下降, 但是总体来说, 我们得到的结果能够说明我们的算法执行 ...

  2. Java中Map<Key, Value>存储结构根据值排序(sort by values)

    需求:Map<key, value>中可以根据key, value 进行排序,由于 key 都是唯一的,可以很方便的进行比较操作,但是每个key 对应的value不是唯一的,有可能出现多个 ...

  3. Java中的排序算法(2)

    Java中的排序算法(2) * 快速排序 * 快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(sub-lists). * 步骤为: * 1. 从数 ...

  4. Java-->把txt中的所有字符按照码表值排序

    --> List 列表中的自动添加的多余空间长度该怎么去除呢?...(已解决,是char 数组中的空字符) package com.dragon.java.filesort; import ja ...

  5. php usort 按照数组中的某个键值排序

    //php usort 按照数组中的某个键值排序 如果第一个参数小于第二个参数 -> 返回小于0的整数如果第一个参数等于于第二个参数 -> 返回等于0的整数如果第一个参数大于于第二个参数 ...

  6. Java中值传递和引用传递的概念

    很多书中都提到了在Java中只存在值传递,但是今天在一个NanoHTTPD的源码中看到这样一段: if (qmi >= 0) { decodeParms(uri.substring(qmi + ...

  7. java中值类型和引用类型的区别

    [定义] 引用类型表示你操作的数据是同一个,也就是说当你传一个参数给另一个方法时,你在另一个方法中改变这个变量的值,那么调用这个方法是传入的变量的值也将改变. 值类型表示复制一个当前变量传给方法,当你 ...

  8. Java集合中对象排序

    集合中的对象排序需求还是比較常见的.当然我们能够重写equals方法,循环比較:同一时候Java为我们提供了更易使用的APIs.当须要排序的集合或数组不是单纯的数字型时,通常能够使用Comparato ...

  9. Comparable与Comparator,java中的排序与比较

    1:比较和排序的概念 比较:两个实体类之间按>,=,<进行比较. 排序:在集合类中,对集合类中的实体进行排序.排序基于的算法基于实体类提供的比较函数. 基本型别都提供了默认的比较算法,如s ...

随机推荐

  1. KT vs SKT [20160816]

    KT:索尔 SKT:茂凯,塔里克,卡西奥佩娅 普朗克+烬,大招开团. 塔里克保护,眩晕.

  2. [IIS]IIS扫盲(三)

      IIS扫盲贴 --==[精品]==--   IIS扫盲贴     --==[精品]==-- 2000对应iis5.0  xp对应iis5.1  2003对应iis6.0        作者: II ...

  3. Python基础篇【第2篇】: Python自定义函数

    Python函数 1. 函数定义 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print ...

  4. [POJ 1988] Cube Stacking (带值的并查集)

    题目链接:http://poj.org/problem?id=1988 题目大意:给你N个方块,编号从1到N,有两种操作,第一种是M(x,y),意思是将x所在的堆放到y所在的堆上面. 第二种是C(x) ...

  5. Biological Filtration

    http://www.fishyou.com/filtration-biological.php Biological Filtration Biological filtration is the ...

  6. php路径目录解析函数dirname basename pathinfo区别及实例

    php获取路径.目录或文件名称,我们经常会使用到dirname().basename().pathinfo()这三个函数,本文章向大家详细介绍这三个函数的区别以及使用实例,需要的朋友可以参考一下. d ...

  7. 项目管理软件之易度1.5,禅道2.0,redmine1.2(附redmine1.2的安装)

    http://www.cnblogs.com/ljzforever/archive/2011/06/29/2093786.html 公司最近准备分出一套人马去客户那里做驻场研发,这就涉及到代码库的统一 ...

  8. 记一次Android内存分析过程

    前言 上周五的时候,祝峰找到我,反映了Android收银台买单结果页内存飙升的问题.我在自己的机器上也试着重现了一下,发现从支付台-微信支付成功并返回后,进入买单结果页的内存会突然增大,导致GC,如图 ...

  9. chrome控制台查看控件有没绑定事件[转]

    chrome控制台查看btn_comment_submit控件有没绑定事件 function lookEvents (elem) {     return $.data ? $.data( elem, ...

  10. postman+newman+jenkins

    1.postman: http://itfish.net/article/59864.html(网上参考资料) 1)安装(要用爬墙软件): 进入下面地址https://chrome.google.co ...