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次,如果数据量更大,目测两者间的数的交换次数差距会更大,即算法的效率差别更大。
- java中冒泡排序与选择排序的区别
- java中冒泡排序与选择排序
- Java中冒泡排序与选择排序
- 冒泡排序与选择排序区别
- 选择排序与冒泡排序的联系和区别
- 选择排序法与冒泡排序法的区别
- java中的冒泡排序与选择排序
- java之冒泡排序与选择排序
- java选择排序与冒泡排序
- 选择排序和冒泡排序的区别
- 选择排序和冒泡排序的区别
- 冒泡排序、选择排序的区别
- 选择排序和冒泡排序的区别
- JAVA之冒泡排序与简单选择排序的实现
- JAVA实现简单的冒泡排序与选择排序
- Java中冒泡排序和选择排序
- java中选择排序和冒泡排序
- java中冒泡排序和选择排序
- 动动乐公司笔试
- 单调队列优化的多重背包
- Matlab 小程序 yuv图片融合
- 剔除单向链表重复值节点时的烦人bug
- POJ3169Layout(线性约束)
- java中冒泡排序与选择排序的区别
- 2013_hangzhou_online
- Markdown语法学习
- 复制表和删除表
- 细说Android框架设计三剑客MVC、MVP和MVVM
- 反编译Android应用
- 【HDU3949】XOR——线性基
- 各种大型网站技术架构
- easy_install 安装、卸载第三方库