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次,如果数据量更大,目测两者间的数的交换次数差距会更大,即算法的效率差别更大。
冒泡算法:假设数组长度为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次,如果数据量更大,目测两者间的数的交换次数差距会更大,即算法的效率差别更大。
相关文章推荐
- java实现冒泡排序,选择排序,插入排序,快速排序(简洁版)及性能测试
- java写的排序(冒泡排序,插入排序,选择排序,快速排序)
- java-冒泡排序和选择排序的分析
- Java常用排序算法冒泡排序与选择排序总结
- java实现冒泡排序,选择排序,直接插入排序,快速排序
- 【java基础】选择排序and冒泡排序
- java实现三种简单排序以及改良:冒泡排序,选择排序,直接插入排序
- java中的三种排序方法使用:选择排序,冒泡排序,sort方法排序。
- java选择排序,冒泡排序分析,附带二分法查找
- 冒泡排序、选择排序、插入排序(java)
- JAVA 冒泡排序 选择排序
- Java中的选择排序和冒泡排序
- JAVA--冒泡排序、选择排序
- 冒泡排序、选择排序的区别
- 黑马程序员—Java基础学习笔记之排序算法:选择排序&冒泡排序
- Java实现排序(快速排序、冒泡排序、选择排序、基数排序、插入排序)
- 冒泡排序与选择排序区别
- 选择排序和冒泡排序的区别
- java数组的排序,选择排序,冒泡排序,插入排序
- java基本算法总结(冒泡排序、选择排序、插入排序)