1、基本思想html
冒泡排序是一种基于数值交换的排序,从第一个元素开始,与后面紧接着的一个元素比较,若是当前这个数更大,则交换二者的数值,那么值更大的元素就像泡泡同样日后走。第n趟排序便可使第n大元素从前日后走。进行n-1次这样的"冒泡操做"后,整个序列就有序了。算法
2、实现代码数组
测试工具类 点击这里dom
public class BubbleSort implements ISort{ public void sort(int[] a) { for(int i = 0; i <= a.length - 3; i++) { boolean isInOrder = true; for(int j = 0; j <= a.length-2-i; j++) { if(a[j] > a[j+1]) { //比较大的数日后面走 int t = a[j]; a[j] = a[j+1]; a[j+1] = t; isInOrder = false; } } if(isInOrder) { //若是某一次循环冒泡没有发生交换,则代表数组已经有序了 break; } } } public static void main(String[] args) { int[] array = RandomArrayGenerator.getRandomArray(100 , 30); SortTestHelper.test(new BubbleSort() , array); }
3、测试结果工具
4、总结分析测试
时间复杂度:O(n2)spa
空间复杂度:O(1)code
稳定性:稳定htm
冒泡排序实现简单,直观易懂,且是稳定的排序算法,但时间复杂度不够理想。blog