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

java冒泡排序

2012-08-17 16:36 246 查看
此排序法是稳定排序算法 。

时间复杂度为O(n²) (n是待排序元素的个数)

空间复杂度为O(1)

import java.util.Arrays;

public class BubbleSort {

/**
* 思路:两两互相比较,大的放后面,第一轮下来,最后一个就是最大的。
*
*/
public static void main(String[] args) {
int[] arr = {3,1,4,7,6,9,8,2};
sort(arr);
System.out.println(Arrays.toString(arr));
//结果:[1, 2, 3, 4, 6, 7, 8, 9]
}

private static void sort(int[] arr) {
int temp = 0;//交换用到的中间量
int compCount = arr.length-1;
for(int i=0; i<compCount; i++) {//控制比较的轮数
for(int j=0; j<compCount-i; j++) {//控制每轮比较的次数,一轮下来,最后一位下在下轮中就不用比了。
//若前面比后面的数大,则交换位置
if(arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: