您的位置:首页 > 编程语言 > Java开发

java中冒泡排序与选择排序的区别

2016-10-15 21:27 267 查看
初学java语言,排序算法绝对是我们拿来实践的好例子。而在排序中有两种简单的算法是绕不开的,就是冒泡排序与选择排序。下面来分别讲解:

冒泡算法:假设数组长度为lenght,冒泡算法的外循环为lenght-1,内循环则为相邻的两个数之间不断比较,直到数组末尾结束。其实现如下。

     public static void main(String[] args) {
int[] arry=new int[]{15,67,26,43,61,25,84,80,34,70};
int temp;
int count=0;

for(int i=1;i<arry.length;i++){
for(int j=0;j<arry.length-i;j++){
if(arry[j]>arry[j+1]){
temp=arry[j];
arry[j]=arry[j+1];
arry[j+1]=temp;
}
}
}
System.out.println("处理后的数据:");
for(int k=0;k<arry.length-1;k++){
System.out.print(arry[k]+" ");
}
System.out.println("jiaohuan:");
System.out.println(count); 
}

       程序运行结果为:

      处理后的数据:

     15 25 26 34 43 61 67 70 80 jiaohuan:

      45

      

       选择排序:假设数组长度为lenght,选择排序的外循环也是lenght-1,内循环则为使用第一个数与其他的数比较,得出一个最小的数,将最小数与数组的第一个元素交换;第二次外循环,则用数组的第二个数与第三到底lenght个数比较,找到其中的最小值,并将此最小值与数组的第二个数交换,一直下去,直到数组末尾。

程序如下所示:

public static void main(String[] args) {
int[] arry=new int[]{15,67,26,43,61,25,84,80,34,70};
int temp;
int count=0;
for(int i=0;i<arry.length-1;i++){
for(int j=i+1;j<arry.length-1;j++){
if(arry[j]>arry[j+1]){
temp=arry[j];
arry[j]=arry[j+1];
arry[j+1]=temp;
count++;
}
}
}
Arrays.sort(arry);
System.out.println("处理后的数据:");
for(int k=0;k<arry.length-1;k++){
System.out.print(arry[k]+" ");
}
System.out.println("jiaohuan:");
System.out.println(count);

}

      

      程序运行结果为:

      处理后的数据:

     15 25 26 34 43 61 67 70 80 jiaohuan:

     12

     可以看到在java环境中选择排序中数的交换次数比冒泡排序少了33次,如果数据量更大,目测两者间的数的交换次数差距会更大,即算法的效率差别更大。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: