JavaScript中sort()方法理解

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()方法功能一樣。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容