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

来源:互联网 发布:函数编程题的心得体会 编辑:程序博客网 时间:2024/06/05 21:49

初学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次,如果数据量更大,目测两者间的数的交换次数差距会更大,即算法的效率差别更大。





0 0
原创粉丝点击