比较Java中冒泡排序,选择排序,快速排序算法效率

讨论从小到大的情况,

冒泡排序算法,通过对数组元素两两比较,把小的往前排,一趟冒泡排序找到一个数组中最小的,虽然没一趟比较的次数会减小,但是如果排序的数组大小很大呢,显然这个算法的效率会变得很低。

算法代码:

for(int i = 0;ia[j+1]) {
					temp = a[j+1];
					a[j+1] = a[j];
					a[j] = temp;
				}
			}
		}

选择排序算法:选择排序算法大概是这样的,定义一个变量存储每一次排序的值以及定义一个minIndex来存储最小值的下标,每一趟排序只交换一次,这样可以比冒泡排序更省时。

算法代码:

for(int i = 0;i

快速排序:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列

如果要实现代码在C,C++中要写很多,但是在Java中的util类库中有一个方法Arrays.sort()括号中将你需要排序的数组名放进去即可,这个方法可以默认的实现从小到大的排序。

那么我们怎么实现从大到小排序呢!

很简单,我们将数组的值逆序输出那么不就可以达到一个降序排序了?

但是循环避免交换过头了,只需要交换的次数为数组长度的一半。

代码:

Arrays.sort(c);
		/***********逆序Arrays.sort()方法********/
		for(int i = 0;i

算法代码:

Arrays.sort(c);

三种排序算法比较:

package shuzu;
/*
 * @ly
 * 比较冒泡排序,选择排序,快速排序的效率
 */
import java.util.*;


public class SpeedOfSortDemo {

	public static void main(String[] args) {
		final int N = 100000;
		int temp;
		long start = System.currentTimeMillis();
		int a[] = new int[N];   //冒泡排序
		int b[] = new int[N];   //选择排序
		int c[] = new int[N];   //快速排序
		/************冒泡排序***********/
		for(int i = 0;ia[j+1]) {
					temp = a[j+1];
					a[j+1] = a[j];
					a[j] = temp;
				}
			}
		}
		long end = System.currentTimeMillis();
		System.out.println("冒泡排序所用时间:"+(end-start)+"ms");
        
		
		/************选择排序***************/
		long start1 = System.currentTimeMillis();
		for(int i = 0;i

运行结果展示:

比较Java中冒泡排序,选择排序,快速排序算法效率_第1张图片

你可能感兴趣的:(alogrithm,Java)