长度为N的数组升序排序

一,冒泡排序

public class BubbleSort {
private double[] data; public BubbleSort(double[] data) {
this.data = data;
} public void sort(){
for(int p = data.length - 1 ; p > 0 ; p--){
for(int i = 0 ; i < p ; i++){
if(data[i] > data[i+1] ){
double tmp = data[i];
data[i] = data[i+1];
data[i+1] = tmp;
}
}
}
} public void display(){
for(int i = 0 ; i < data.length ; i++){
System.out.print(data[i]+" ");
}
System.out.print("\n");
} public static void main(String[] args) {
double[] data = {Math.random(),Math.random(),Math.random(),Math.random()};
BubbleSort bubbleSort = new BubbleSort(data);
bubbleSort.display();
bubbleSort.sort();
bubbleSort.display();
}
}
0.4125010895286405 0.1682061731460387 0.5946448214944792 0.2760597727054087
0.1682061731460387 0.2760597727054087 0.4125010895286405 0.5946448214944792

比较次数:第一次比较N-1次,第二次比较N-2次,总比较次数为(N-1) + (N-2) +...+ 1 = (N-1)*N/2

交换次数:如果数组本身为降序排序,则需交换(N-1)*N/2次,如果数组本身为升序排序,则需交换0次,如果数据是随机的,大约需要交换(N-1)*N/4次

时间复杂度:(N-1)*N/2 + (N-1)*N/4,总得来说为O(N*N)

二,选择排序

public class SelectSort {
private double[] data; public SelectSort(double[] data){
this.data = data;
} public void sort(){
for(int i = 0 ; i < data.length ; i++){
int flag = i;
for(int j = i + 1 ; j < data.length ; j++){
if( data[j] < data[flag]){
flag = j;
}
}
double tmp = data[i];
data[i] = data[flag];
data[flag] = tmp;
}
} public void display(){
for(int i = 0 ; i < data.length ; i++){
System.out.print(data[i]+" ");
}
System.out.print("\n");
} public static void main(String[] args) {
double[] data = {Math.random(),Math.random(),Math.random(),Math.random()};
SelectSort selectSort = new SelectSort(data);
selectSort.display();
selectSort.sort();
selectSort.display();
}
}
0.8992760265680794 0.36366208723355853 0.5105026583966352 0.27067878126430966
0.27067878126430966 0.36366208723355853 0.5105026583966352 0.8992760265680794

比较次数:第一次比较N-1次,第二次比较N-2次,总比较次数为(N-1) + (N-2) +...+ 1 = (N-1)*N/2

交换次数:如果数组本身为降序排序,则需交换N次,如果数组本身为升序排序,则需交换0次,如果数据是随机的,大约需要交换N/2次

时间复杂度:(N-1)*N/2 + N/2,总得来说为O(N*N),但是会比冒泡排序快

三,插入排序

public class InsertSort {
private double[] data; public InsertSort(double[] data) {
this.data = data;
} public void sort(){
for(int i = 1 ; i < data.length ; i++){
double tmp = data[i];
int insertPoint = i;
while(insertPoint > 0 && data[insertPoint-1] > tmp){
data[insertPoint] = data[insertPoint-1];
--insertPoint;
}
if(insertPoint < i){
data[insertPoint] = tmp;
}
}
} public void display(){
for(int i = 0 ; i < data.length ; i++){
System.out.print(data[i]+" ");
}
System.out.print("\n");
} public static void main(String[] args) {
double[] data = {Math.random(),Math.random(),Math.random(),Math.random()};
InsertSort insertSort = new InsertSort(data);
insertSort.display();
insertSort.sort();
insertSort.display();
}
}
0.25855304984386873 0.5035006863323077 0.8986028814892651 0.724194607320699
0.25855304984386873 0.5035006863323077 0.724194607320699 0.8986028814892651

比较次数:第一次比较1次,第二次比较2次,总比较次数为1+2+...+(N-1)= (N-1)*N/2,每一趟排序发现插入点之前,平均只有一半的数据进行了比较,所以总的比较次数为:(N-1)*N/4

交换次数:交换次数小于比较次数,并且插入排序的交换比冒泡排序和选择排序要快

时间复杂度:(N-1)*N/4 + (N-1)*N/4,总得来说为O(N*N),但是会比选择排序快

如果数组是基本有序的,即每个数据项只需移动1次或不需要移动,那么插入排序的时间复杂度将变为O(N),这无疑是非常快的

四,表排序

主要是利用了有序链表的特性,将数组中的所有数据插入到有序链表中,它们将自动按顺序排列,然后再顺次取出链表中的所有数据,把它们放到数组中,数组便排好序了

public class SortedList {
private class Data{
private double d;
private Data next = null; Data(double d){
this.d = d;
}
} private Data first = null; public void insert(double d){
Data data = new Data(d);
Data pre = null;
Data cur = first;
while(cur != null && (data.d > cur.d)){
pre = cur;
cur = cur.next;
}
if(pre == null)
first = data;
else
pre.next = data;
data.next = cur;
} public double deleteFirst() throws Exception{
if(first == null)
throw new Exception("empty!");
Data temp = first;
first = first.next;
return temp.d;
}
}
public class ListSort {
private double[] data;
private SortedList sl; public ListSort(double[] data){
this.data = data;
sl = new SortedList();
} public void sort() throws Exception{
for(int i = 0 ; i< data.length ; i++){
sl.insert(data[i]);
}
for(int i = 0 ; i< data.length ; i++){
data[i] = sl.deleteFirst();
}
} public void display(){
for(int i = 0 ; i < data.length ; i++){
System.out.print(data[i]+" ");
}
System.out.print("\n");
} public static void main(String[] args) throws Exception{
double[] data = {Math.random(),Math.random(),Math.random(),Math.random()};
ListSort ls = new ListSort(data);
ls.display();
ls.sort();
ls.display();
}
}
0.6379262500544237 0.18329827548195576 0.8408253367598466 0.6213596557610592
0.18329827548195576 0.6213596557610592 0.6379262500544237 0.8408253367598466

比较次数:将数据插入链表平均需要比较N/2次

交换次数:将数组数据放入链表,再将链表数据放回数组,总共需移动2N次

时间复杂度:N/2 + 2N,总得来说为O(N)

虽然排序速度比上面3种排序方式要快,但是需要大约2倍的内存空间,数组和链表同时存在于内存中

Java基本排序的更多相关文章

  1. Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法

    Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...

  2. Java 常用排序算法/程序员必须掌握的 8大排序算法

    Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...

  3. java 集合排序(转)

    Java API针对集合类型排序提供了两种支持:java.util.Collections.sort(java.util.List)java.util.Collections.sort(java.ut ...

  4. java:高速排序算法与冒泡排序算法

     Java:高速排序算法与冒泡算法 首先看下,冒泡排序算法与高速排序算法的效率: 例如以下的是main方法: /**   *  * @Description:  * @author:cuiyaon ...

  5. java常见排序方法

    1.java常用排序方法 1) 选择排序         原理:a. 将数组中的每个元素,与第一个元素比较          如果这个元素小于第一个元素, 就将这个         两个元素交换.   ...

  6. java希尔排序

    java希尔排序 1.基本思想: 希尔排序也成为"缩小增量排序",其基本原理是,现将待排序的数组元素分成多个子序列,使得每个子序列的元素个数相对较少,然后对各个子序列分别进行直接插 ...

  7. Java八大排序算法

    Java八大排序算法: package sort; import java.util.ArrayList; import java.util.Arrays; import java.util.List ...

  8. Java常用排序算法及性能测试集合

    测试报告: Array length: 20000 bubbleSort : 573 ms bubbleSortAdvanced : 596 ms bubbleSortAdvanced2 : 583 ...

  9. java 集合排序

    Java API针对集合类型排序提供了两种支持:java.util.Collections.sort(java.util.List)java.util.Collections.sort(java.ut ...

  10. Java各种排序算法

      Java各种排序算法详解 排序大的分类可以分为两种:内排序和外排序.在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序.下面讲的排序都是属于内排序. 内排序有 ...

随机推荐

  1. Failed to lunch test error when run with Appium (已解决)

    [2015-08-10 15:09:07 - androidtest1] Performing android.test.InstrumentationTestRunner JUnit launch[ ...

  2. Oracle学习网址

    Oracle Error Search: http://www.ora-error.com/ Oracle Database Error Message - Oracle Documentation: ...

  3. opencv 在工业中的应用:二维标定

    在工业中经常要检测一个零件的尺寸,但是图像处理得到的是像素值,怎么才能得到实际的毫米值呢?这就要用到二维标定,我用OPENCV写了一个利用标定板进行标定的DEMO. 很多商业软件都没有二维标定的功能, ...

  4. Apache启动是出现the requested operation has failed

    出现的原因: 原因一:80端口占用例如IIS,另外就是迅雷. 原因二:软件冲突装了某些软件会使apache无法启动如Dr.com 你打开网络连接->TcpIp属性->高级->WINS ...

  5. 使用Markdown编辑器写博客

    使用Markdown编辑器写博客 本Markdown编辑器使用StackEdit修改而来,用它写博客,将会带来全新的体验哦: Markdown和扩展Markdown简洁的语法 代码块高亮 图片链接和图 ...

  6. Android实例-操作sqlite数据之自建导航(XE8+小米2)

    相关资料: 源文:http://blog.sina.com.cn/s/blog_77691fb90101g9hh.html help://embarcadero.rs_xe5/rad/Mobile_T ...

  7. Winodws安装系统时,通过安装磁盘进行分区

    今天使用一个系统盘安装的时候,很奇怪,分区总是分出来一个系统磁盘,一个MBR,剩下的只能分主分区. 这样就导致我在进行windows激活时,激活工具都找不到启动磁盘的盘符(因为自动分出来的系统磁盘和M ...

  8. linux mail命令用法

    在Linux系统下mail命令的测试 1. 最简单的一个例子: mail -s test admin@aispider.com 这条命令的结果是发一封标题为test的空信给后面的邮箱,如果你有mta并 ...

  9. 第二周:01 ICP迭代交互

    本周主要任务01:利用PCL库函数,ICP融合两个角度的点云 任务时间:2014年9月8日-2014年9月14日 任务完成情况:可以使用键盘交互,显示每次ICP迭代结果 任务涉及基本方法: 1.PCL ...

  10. 较具体的介绍JNI

    JNI事实上是Java Native Interface的简称,也就是java本地接口.它提供了若干的API实现了和Java和其它语言的通信(主要是C&C++).或许不少人认为Java已经足够 ...