java冒泡排序
2012-08-17 16:36
246 查看
此排序法是稳定排序算法 。
时间复杂度为O(n²) (n是待排序元素的个数)
空间复杂度为O(1)
时间复杂度为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; } } } } }