使用JavaScript Array.sort() 進行混排
在JavaScript 中,使用帶有自訂比較函數的Array.sort( ) 方法打亂數組是一種複雜且可能不可靠的方法。
為什麼Array.sort() 並不是最適合洗牌
替代洗牌方法:Fisher-Yates
Fisher-Yates 洗牌演算法是一種高效可靠的重新排列數組的方法以隨機順序。它的運作原理如下:
function shuffle(array) { var tmp, current, top = array.length; if(top) while(--top) { current = Math.floor(Math.random() * (top + 1)); tmp = array[current]; array[current] = array[top]; array[top] = tmp; } return array; }
為什麼費雪-耶茨是首選
測量隨機播放隨機性
要評估洗牌演算法的隨機性,您可以計算統計數據,例如:
基於這些指標,Fisher-Yates 往往會比 Array.sort() 產生更均勻分佈和隨機的打亂。
以上是為什麼在 JavaScript 中,Fisher-Yates 優於 Array.sort() 進行重組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!