sort() 方法用于對數(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()方法功能一樣扩然。