亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用js隨機函數Math.random實現亂序的方法

發布時間:2020-07-23 14:42:49 來源:億速云 閱讀:344 作者:小豬 欄目:web開發

這篇文章主要講解了使用js隨機函數Math.random實現亂序的方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

亂序的意思想必沒有不知道:就是將數組打亂。聽到亂序一般都會想到js的隨機函數Math.random();

var values = [1, 2, 3, 4, 5];
values.sort(function() {
  return Math.random() - 0.5;
});
console.log(values)

利用數組的sort方法,判斷隨機出來的0~1值與0.5的大小,實現排序。看似一個很不錯的方案,代碼邏輯也沒毛病,一般情況下也確實能夠做到亂序。但是,這是一個偽排序,是的還有但是(我也是今天才知道的,不求甚解的毛病啊~),為什么呢?先看看這個亂序的結果吧:

var times = [0, 0, 0, 0, 0];
for (var i = 0; i < 100000; i++) {
  let arr = [1, 2, 3, 4, 5];
  arr.sort(() => Math.random() - 0.5);
  times[arr[4] - 1]++;
};
console.log(times)

測試的原理是:將[1, 2, 3, 4, 5]亂序10萬次,計算亂序后數組的最后一個元素是1,2,3,4,5的次數分別是多少。

運行幾次得到的結果為:

使用js隨機函數Math.random實現亂序的方法使用js隨機函數Math.random實現亂序的方法使用js隨機函數Math.random實現亂序的方法

由這幾次運行得到的結果可以看出:2出現的最后的次數明顯少于其他數字,不是隨機嗎?按理說概率應該是相差不多才對啊!
其實問題是在sort方法,各個瀏覽器對sort的實現方式不一樣。

Chrome的sort

基于V8引擎,它的排序算進行了很多的優化,但是核心是小于等于10的數組用插入排序(穩定),大于10的采用了quickSort(不穩定)

FireFox的sort

基于SpiderMonkey引擎,采用了歸并排序(穩定)

Safari的sort

基于Nitro(JavaScriptCore )引擎,如果沒有自定義的排序規則傳入,采用桶排序(不一定穩定, 桶排序的穩定性取決于桶內排序的穩定性, 因此其穩定性不確定。),傳入自定義規則,采用歸并排序(穩定)

Microsoft Edge/IE9+

基于Chakra引擎,采用快排(不穩定)

以下用chrome測試亂序各種結果的概率:

var times = 100000;
var res = {};
for(var i = 0; i < times; i++){
  var arr = [1, 2, 3];
  arr.sort(() => Match.random() - 0.5);
  var key = JSON.stringify(arr);
  res[key] &#63; res[key]++ : res[key] = 1;
}

// 為了方便展示,轉換成百分比
for (var key in res) {
  res[key] = res[key] / times * 100 + '%';
}
console.log(res);

結果如下

使用js隨機函數Math.random實現亂序的方法

幾種結果出現的概率相差很大...所以說不是一個真正的亂序。

Fisher-Yates算法【也叫“洗牌算法”】:為什么叫 Fisher–Yates 呢? 因為這個算法是由 Ronald Fisher 和 Frank Yates 首次提出的。代碼如下:

function shuffle(a) {
  var j, x, i;
  for (i = a.length; i; i--) {
    j = Math.floor(Math.random() * i);
    x = a[i-1];
    a[i - 1] = a[j];
    a[j] = x;
  }
  return a;
}

其原理就是:遍歷數組元素,然后將當前元素與以后隨機位置的元素進行交換,這樣亂序更加徹底。

如果用ES6的寫法還能精簡成:

function shuffle(a) {
  for(let i = a.length; i; i--) {
    let j = Math.floor(Math.random() * i);
    [a[i - 1], a[j]] = [a[j], a[i - 1]];
  }
  return a;
}

再用上面的demo測試一下:

var times = 100000;
var res = {};

for (var i = 0; i < times; i++) {
  var arr = shuffle([1, 2, 3]);

  var key = JSON.stringify(arr);
  res[key] &#63; res[key]++ : res[key] = 1;
}

// 為了方便展示,轉換成百分比
for (var key in res) {
  res[key] = res[key] / times * 100 + '%'
}

console.log(res)

得到結果如下:

使用js隨機函數Math.random實現亂序的方法

各種結果的概率都基本相同了,所以真正實現了亂序的效果!

看完上述內容,是不是對使用js隨機函數Math.random實現亂序的方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

武平县| 巴塘县| 顺平县| 施甸县| 定西市| 水富县| 马龙县| 巴南区| 汝阳县| 依兰县| 皮山县| 阳谷县| 克山县| 揭阳市| 法库县| 江北区| 容城县| 阿城市| 百色市| 谢通门县| 平定县| 孟津县| 永德县| 日土县| 肃南| 游戏| 长治市| 万荣县| 巍山| 南充市| 蒙山县| 东海县| 五寨县| 吉隆县| 扎兰屯市| 改则县| 宝清县| 木里| 南城县| 秦安县| 南昌市|