如何随机(shuffle)JavaScript数组?

阅读时长 3 分钟读完

在前端开发中,有时需要将一个数组的元素顺序打乱,即实现“随机”(shuffle)操作。本文将介绍如何用JavaScript来实现这一操作。

方法一:洗牌法

洗牌法是一种常见的打乱数组元素顺序的方法。其基本思路是从数组的最后一个元素开始,不断地向前扫描,然后将当前元素和前面某个随机位置的元素交换位置。重复该过程直至当前元素到达数组的第一个位置。

以下是一个基于洗牌法的JavaScript函数实现:

该函数接受一个数组作为参数,并使用for循环对数组进行遍历。在每次循环中,通过Math.random()方法生成一个0到1之间的随机数,然后将其乘以(i+1),再取其下整数,得到一个0到i之间的随机整数j。最后,将第i个元素和第j个元素交换位置。

方法二:递归切分

递归切分法也是一种常见的打乱数组元素顺序的方法。其基本思路是将数组随机地切分成两部分,然后递归地对每一部分进行打乱操作。最终将这些部分合并起来即可得到一个打乱顺序的数组。

以下是一个基于递归切分法的JavaScript函数实现:

-- -------------------- ---- -------
-------- -------------- -
  -- ------------- -- -- -
    ------ ------
  -
  ----- ---- - ---
  ----- ----- - ---
  ----- ----- - ------------------------ - --------------
  --- ---- - - -- - - ------------- ---- -
    -- -- --- ------ -
      -- -------------- - ---- -
        --------------------
      - ---- -
        ---------------------
      -
    -
  -
  ------ ------------------ ------------- -------------------
-

该函数首先检查数组长度是否小于等于1,如果是则直接返回该数组。否则,随机选取一个元素作为“轴点”(pivot),然后遍历数组中的每个元素,并根据一定的概率将其放入左半部分或右半部分。最后,将左半部分、轴点和右半部分合并起来,得到一个打乱顺序的数组。

总结

本文介绍了两种常见的打乱数组元素顺序的方法:洗牌法和递归切分法。无论哪种方法,都可以很好地实现数组的随机操作。在实际开发中,可以根据具体情况选择合适的方法。

示例代码可在 GitHub Gist 中查看和下载。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/7959

纠错
反馈