比较相邻的元素。若是第一个比第二个大,就交换他们两个。javascript
对每一对相邻元素做一样的工做,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。java
针对全部的元素重复以上的步骤,除了最后一个。spa
持续每次对愈来愈少的元素重复上面的步骤,直到没有任何一对数字须要比较。code
效率:ip
时间复杂度:平均 O(n)io
空间复杂度:须要辅助空间 O(1)console
稳定性:稳定function
js代码:class
function bubbleSort(arr) { var i = arr.length, j; var tempExchangVal; while (i > 0) { for (j = 0; j < i - 1; j++) { if (arr[j] > arr[j + 1]) { tempExchangVal = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = tempExchangVal; } } i--; } return arr; } var arr = [3, 2, 4, 9, 1, 5, 7, 6, 8]; console.log("before: "+arr); var arrSorted = bubbleSort(arr); console.log(" after: "+arrSorted);