sort() 方法用于對(duì)數(shù)組的元素進(jìn)行排序
sort可以傳入?yún)?shù),也可以不傳參數(shù),下面分別說明。
不帶參數(shù)
<script type="text/javascript">
var arr = new Array(6)
arr[0] = "10"
arr[1] = "5"
arr[2] = "40"
arr[3] = "25"
arr[4] = "1000"
arr[5] = "1"
document.write(arr + "<br />")
document.write(arr.sort())
</script>```
此時(shí)的輸出是按照字符串的字典順序來排列,輸出如下:
排序前:10,5,40,25,1000,1
排序后:1,10,1000,25,40,5
這種排序結(jié)果在很多情況下都不是最佳方案。那么,我們需要給sort方法傳入一個(gè)比較函數(shù)作為參數(shù)。
***
#####比較函數(shù)作為參數(shù)
<script type="text/javascript">
function sortNumber(a,b){
return a - b
}
var arr = new Array(6)
arr[0] = "10"
arr[1] = "5"
arr[2] = "40"
arr[3] = "25"
arr[4] = "1000"
arr[5] = "1"
document.write(arr + "<br />")
document.write(arr.sort(sortNumber))
</script>
將比較函數(shù)作為參數(shù)傳給sort()方法后,數(shù)值排序得到了我們想要的結(jié)果:
排序前:10,5,40,25,1000,1
排序后:1,5,10,25,40,1000
**sort()方法如何排序呢**,下面是我總結(jié)的流程,供參考:
1.sort方法將arr數(shù)組的值兩兩傳入sortNumber函數(shù),返回的值有3種情況:正數(shù),負(fù)數(shù),零。
2.若sort方法接收到正數(shù)返回值,則交換傳入sortNumber的兩個(gè)數(shù)字,即當(dāng)傳入的a>b,則交換a與b;若sort方法接收到負(fù)數(shù)返回值和0返回值,則不交換。
3.重復(fù)1和2,最終使數(shù)字按照從小到大的順序排序。
**以上述代碼為例,流程如下**:
1. 將a=10,b=5傳入sortNumber,返回5,正數(shù),則將10和5交換順序,此時(shí)arr數(shù)組順序?yàn)椋?,10,40,25,1000,1
2. 將a=10,b=40傳入sortNumber,返回-30,負(fù)數(shù),不改變順序。此時(shí)arr數(shù)組順序仍為:5,10,40,25,1000,1
3. 將a=40,b=25傳入,返回15,正數(shù),交換順序,此時(shí)arr數(shù)組順序:5,10,25,40,1000,1
4. 將a=40,b=1000傳入,返回負(fù)數(shù),不改變順序,此時(shí)arr數(shù)組順序:5,10,25,40,1000,1
5. 將a=1000,b=1傳入,返回正數(shù),交換,此時(shí)arr數(shù)組順序:5,10,25,40,1,1000
此時(shí),最大的元素被排到最后面了。是不是覺得很熟悉,沒錯(cuò),這就是冒泡算法的第一階段,接下來,sort會(huì)接著將5,10傳入sortNumber,進(jìn)行第二階段的排序。因此我們可以總結(jié)出,sort(sortNumber)里面自動(dòng)進(jìn)行的就是**冒泡排序法**。
**舉一反三**,如果我們給sort()方法參數(shù)傳1,即sort(1),那么結(jié)果就是數(shù)組項(xiàng)順序反轉(zhuǎn),和reverse()方法功能一樣。