package com.xj.www.sort;
/**
* 优化后的冒泡排序
*
* @author xiongjing
*
*/
public class BubbleSort {
/**
* 冒泡排序具体流程实现如下:
* 1.对数组中的各数据,依次比较相邻的两个元素的大小。
* 2.如果前面的数据大于后面的数据,就交换这个两个数据。
* 经过第一轮的多次比较排序后,便可将最小的数据排好。
* 3.再用同样的方法把剩下的数据逐个进行比较,最后便可按照从小到大的顺序排好数组个数据。
*/
static final int SIZE = 10;
static void bubbleSort(int[] a) {
boolean flag = true;
int temp;
for (int i = 1; i < a.length; i++) {
// 设置标志
flag = true;
for (int j = 0; j < a.length - i; j++) {
if (a[j] > a[j + 1]) {
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
// 如果还能交换则证明排序还没有完成
flag = false;
}
}
// 判断排序是否已经完成
if (flag) {
break;
}
System.out.print("第" + i + "步排序结果:");
for (int k = 0; k < a.length; k++) {
System.out.print(" " + a[k]);
}
System.out.print("\n");
}
}
// 程序主入口
public static void main(String[] args) {
long startTime = System.currentTimeMillis();
int[] shuzu = new int[SIZE];
int i;
for (i = 0; i < SIZE; i++) {
shuzu[i] = (int) (100 + Math.random() * (100 + 1));
}
System.out.print("排序前的数组为:\n");
for (i = 0; i < SIZE; i++) {
System.out.print(shuzu[i] + " ");
}
System.out.println("\n");
bubbleSort(shuzu);
System.out.print("排序后的数组为:\n");
for (i = 0; i < SIZE; i++) {
System.out.print(shuzu[i] + " ");
}
System.out.print("\n");
long endTime = System.currentTimeMillis();
long totalTime = endTime - startTime;
System.out.println("总共用时:"+totalTime);
}
}
冒泡排序
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 选择排序 对于任何输入,时间为O(n*n); 冒泡排序 最优(对于升序的数组,因为加入了一个跳出判断):O(n),...
- 冒泡排序 大的下沉,小的上浮。 每次循环都从头(0)开始比较到(attr.length-循环次数)位置,每次...
- 今天点击社保小程序某个月份的缴费详情弹框的时候,提示如图所示的错误image.png 经过断点调试,发现是以下代码...