怎么在 JavaScript 中实现一个 shuffle 数组

首页 / 常见问题 / 低代码开发 / 怎么在 JavaScript 中实现一个 shuffle 数组
作者:开发工具 发布时间:24-10-31 14:03 浏览量:9337
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

一、简介

在JavaScript中实现一个数组的随机洗牌可以使用几种不同的算法,包括Fisher-Yates算法(又称Knuth洗牌算法)、简单的随机索引交换、及现代浏览器内置的Array.sort()方法搭配随机比较函数。其中Fisher-Yates洗牌算法以其高效、公正的随机性而著称,是执行此任务的最佳方式之一。

Fisher-Yates洗牌算法是一种从最后一个元素开始,遍历数组中的每一个元素,每次随机选择一个元素与当前位置的元素进行交换的过程。这种方法确保了每个元素在洗牌后都有相同的概率处于数组的任意位置。

二、FISHER-YATES 洗牌算法

Fisher-Yates洗牌算法(Knuth洗牌算法)是一种运行效率很高的洗牌方法,它能够确保洗牌结果每一个可能出现的排列都是等可能的,即洗牌是公平的。

实现步骤

  1. 从数组的末尾开始遍历,对于数组中剩下的每个元素(从最后一个元素向第一个元素遍历),执行第2和第3步骤;
  2. 随机选择一个元素,这个元素是从第一位置到当前遍历位置(包括遍历位置)的任何一个元素;
  3. 交换这两个元素的位置,继续对前一个元素进行这个过程,直至遍历到数组的第一个元素。

代码示例

function shuffle(array) {

for (let i = array.length - 1; i > 0; i--) {

const randomIndex = Math.floor(Math.random() * (i + 1));

[array[i], array[randomIndex]] = [array[randomIndex], array[i]];

}

return array;

}

这段代码利用了ES6的解构赋值来交换数组元素的位置,避免了使用临时变量而导致的额外内存开销。

三、简单随机索引交换

一种较为粗糙但实现简单的洗牌方法是通过简单的随机索引交换。这种方法可能会导致某些元素的位置更容易变化,而有些则较为固定,故并不推荐使用。

实现步骤

  1. 定义交换次数,通常是数组长度的2-3倍为宜;
  2. 生成两个随机索引,并在这两个索引之间交换元素。

代码示例

function simpleShuffle(array) {

const swapTimes = array.length * 2; // 定义交换次数

for (let i = 0; i < swapTimes; i++) {

const index1 = Math.floor(Math.random() * array.length);

const index2 = Math.floor(Math.random() * array.length);

if (index1 !== index2) {

[array[index1], array[index2]] = [array[index2], array[index1]];

}

}

return array;

}

这里同样利用了ES6的语法简化交换逻辑。

四、USING ARRAY.SORT WITH A RANDOM COMPARISON FUNCTION

我们还可以通过使用JavaScript的Array.sort()方法结合一个随机比较函数来实现一个简单的洗牌操作。这种方法的随机性并不及Fisher-Yates算法,且某些JavaScript引擎可能对这种随机排序实现做出了优化,使得其表现不尽人意。

实现步骤

  1. 调用Array.sort()方法
  2. 传递一个随机比较函数,该函数返回-0.5至0.5之间的随机数。

代码示例

function sortShuffle(array) {

return array.sort(() => 0.5 - Math.random());

}

尽管代码非常简洁,但由于其随机性较差,因此并不推荐用于需要公平随机性的场合。

五、结论

在JavaScript中实现数组的随机洗牌,建议使用Fisher-Yates洗牌算法。它不仅能够以最小的代价保证随机性,而且是易于实现且性能良好的算法。其他方法可能会更简单,但牺牲了洗牌的公正性和随机性。当需要在实际应用中进行数组的洗牌时,应优先选用被广泛认可的算法,以保证结果的随机性和公正性。

相关问答FAQs:

如何使用 JavaScript 来对数组进行洗牌操作?

JavaScript提供了多种方法来对数组进行洗牌操作,以下是一种简单的实现方式:

function shuffleArray(array) {
  var currentIndex = array.length, temporaryValue, randomIndex;
  
  while (currentIndex !== 0) {

    randomIndex = Math.floor(Math.random() * currentIndex);
    currentIndex -= 1;

    temporaryValue = array[currentIndex];
    array[currentIndex] = array[randomIndex];
    array[randomIndex] = temporaryValue;
  }

  return array;
}

这个函数将接收一个数组作为参数并返回一个经过洗牌后的数组。它使用了Fisher-Yates算法来进行洗牌操作。该算法从数组末尾开始,将当前元素与一个随机位置上的元素进行交换,然后将当前索引递减1,直到遍历完整个数组。

使用该函数可以将任何类型的数组进行洗牌,如数字数组、字符串数组等。调用示例如下:

var numbers = [1, 2, 3, 4, 5];
var shuffledNumbers = shuffleArray(numbers);
console.log(shuffledNumbers);
var colors = ['red', 'green', 'blue', 'yellow'];
var shuffledColors = shuffleArray(colors);
console.log(shuffledColors);

如何在 JavaScript 中实现一个随机洗牌算法?

要在JavaScript中实现一个随机洗牌算法,可以按照以下步骤进行:

  1. 遍历数组,从最后一个元素开始,向前循环。
  2. 在每次循环中,生成一个随机索引(范围是当前元素的索引到数组结尾)。
  3. 将当前元素与随机索引位置上的元素进行交换。
  4. 重复执行上述步骤直到遍历完整个数组。

以下是一个实现示例:

function randomShuffle(array) {
  var currentIndex = array.length, temporaryValue, randomIndex;
  
  while (currentIndex !== 0) {

    randomIndex = Math.floor(Math.random() * currentIndex);
    currentIndex -= 1;

    temporaryValue = array[currentIndex];
    array[currentIndex] = array[randomIndex];
    array[randomIndex] = temporaryValue;
  }

  return array;
}

可以通过调用该函数来对任何类型的数组进行随机洗牌,如数字数组、字符串数组等。

如何使用 JavaScript 对数组进行乱序处理?

要使用JavaScript对数组进行乱序处理,可以借助洗牌算法来实现。以下是一种简单的乱序处理的方法:

function shuffleArray(array) {
  var currentIndex = array.length, temporaryValue, randomIndex;
  
  while (currentIndex !== 0) {

    randomIndex = Math.floor(Math.random() * currentIndex);
    currentIndex -= 1;

    temporaryValue = array[currentIndex];
    array[currentIndex] = array[randomIndex];
    array[randomIndex] = temporaryValue;
  }

  return array;
}

你可以调用该函数将任何类型的数组进行乱序处理,如数字数组、字符串数组等。

下面是一个使用示例:

var numbers = [1, 2, 3, 4, 5];
var shuffledNumbers = shuffleArray(numbers);
console.log(shuffledNumbers);
var colors = ['red', 'green', 'blue', 'yellow'];
var shuffledColors = shuffleArray(colors);
console.log(shuffledColors);

通过调用该函数,你可以在不改变原始数组的情况下获得一个乱序处理后的新数组。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

怎么改造研发团队研发流程
01-17 18:02
团队技术研发流程表怎么做
01-17 18:02
如何优化研发流程以缩短产品上市时间
01-17 18:02
研发流程团队 职责是什么
01-17 18:02
软件传统研发流程包括什么
01-17 18:02
研发流程用什么软件做
01-17 18:02
低代码后台:《低代码后台开发指南》
01-17 17:28
后台低代码:《后台低代码开发技巧》
01-17 17:28
国内最强低代码开发平台:《国内顶尖低代码平台》
01-17 17:28

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流