详解js数组的完全随机排列算法

yizhihongxing

详解JS数组的完全随机排列算法

1. 算法原理

完全随机排列算法是指将一个数组中的元素完全随机地排列,使每个元素出现在每个位置的可能性相同。

算法的实现原理是:

  1. 从数组的最后一个位置开始依次向前遍历,对于每个位置i,随机生成一个介于[0,i]之间的整数j
  2. 将位置i上的元素与位置j上的元素交换

经过这样的遍历,整个数组就被完全随机排列了。

2. JS代码实现

以下是JS代码的实现:

function shuffle(array) {
    var len = array.length;
    for (var i = len - 1; i >= 0; i--) {
        var j = Math.floor(Math.random() * (i + 1));
        var temp = array[i];
        array[i] = array[j];
        array[j] = temp;
    }
    return array;
}

代码中的参数array是需要被随机排列的数组,返回值为排列好的新数组。具体实现中,从后向前遍历数组,每次生成介于[0,i]之间的随机数j,然后将位置i上的元素与位置j上的元素进行交换,这样最终遍历完数组后得到的就是一个完全随机排列的新数组。

3. 示例说明

示例1: 随机排序一组数组

var arr1=[1, 2, 3, 4, 5, 6];
var arr2=shuffle(arr1);
console.log(arr2);

示例1演示了如何将一个数组随机排列,并将排列后的新数组存入另一个数组。

示例2:打乱一组DOM元素的顺序

var domList= document.querySelectorAll('.item');
var shuffledDomList = shuffle(domList);
for (var i = 0; i < shuffledDomList.length; ++i) {
  container.appendChild(shuffledDomList[i]);
}

示例2演示了如何将一个DOM元素列表随机排列,然后按照新的顺序插入到文档中的父容器中。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解js数组的完全随机排列算法 - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • JS实现的冒泡排序,快速排序,插入排序算法示例

    为了给大家更好的理解,这里先介绍一下这三种排序算法的基本思想: 冒泡排序:依次比较相邻两个元素的大小,将较大的元素往后移动,每一轮比较都可以确定一个最大的元素,因此需要进行N-1轮。 快速排序:选定一个中心点,将小于这个中心点的元素排在左边,大于这个中心点的元素排在右边,然后分别对左右两边的元素重复这个操作。 插入排序:将数组按升序排列,一次将每个元素插入到…

    算法与数据结构 2023年5月19日
    00
  • Java中集合和数组的排序方式小结

    Java中集合和数组的排序方式小结 数组排序 Java中可以使用Arrays类提供的sort()方法对数组进行排序。sort()方法有两个重载版本: sort(int[] a):对int类型的数组进行升序排序 sort(Object[] a):对实现了Comparable接口的对象数组进行升序排序 示例1:对int类型的数组进行升序排序 int[] arr …

    算法与数据结构 2023年5月19日
    00
  • PHP快速排序quicksort实例详解

    PHP快速排序quicksort实例详解 本文将详细介绍如何使用PHP实现快速排序算法,并提供两个示例进行说明。 基本思路 快速排序是一种比较常见的排序算法,其基本思路是通过递归将待排序数组分割成更小的子数组,并把比基准值小的元素一次放到基准值左边,比基准值大的元素一次放到基准值右边,然后对左右两边分别递归执行上述操作,直到分割成的子数组长度为1,此时由于子…

    算法与数据结构 2023年5月19日
    00
  • C#常见算法面试题小结

    C#常见算法面试题小结 常见算法 本文主要讲解C#常见算法,在面试或实际工作中应用较为广泛。以下是本文讨论的常见算法: 排序算法 查找算法 贪心算法 动态规划算法 字符串算法 排序算法 冒泡排序 冒泡排序是一种效率低下的排序,但是学习它有助于了解其他的排序算法。 冒泡排序的核心思想是重复地走访过要排序的序列,每次比较相邻的两个元素,如果他们的顺序错误就把他们…

    算法与数据结构 2023年5月19日
    00
  • Golang排列组合算法问题之全排列实现方法

    下面是对于“Golang排列组合算法问题之全排列实现方法”的完整攻略: Golang排列组合算法问题之全排列实现方法 什么是全排列 全排列,即在一组数的排列中,若任意两个数的位置不同,则称它们的排列是不同的。要求多少个不同的排列数,通常用全排列求解。 全排列实现方法 全排列的实现方式可以采用递归或迭代的方式。 递归实现方式 递归的思想是每次确定一个位置的数字…

    算法与数据结构 2023年5月19日
    00
  • 几种经典排序算法的JS实现方法

    一、冒泡排序 原理 冒泡排序将待排序元素两两比较,根据比较结果交换位置,一遍冒泡会让至少一个元素到达最终位置。重复这个过程,直到排序完成。 JS实现 function bubbleSort(arr) { const len = arr.length; for (let i = 0; i < len; i++) { for (let j = 0; j &…

    算法与数据结构 2023年5月19日
    00
  • 详解JavaScript如何实现四种常用排序

    详解JavaScript如何实现四种常用排序 排序是计算机科学中的重要概念,其主要目的是将一组元素按照一定规则进行排序,便于使用。常见的排序算法有四种:冒泡排序、插入排序、选择排序和快速排序。本文将详细讲解如何使用JavaScript实现这四种常用排序。 冒泡排序 冒泡排序是最简单的排序算法之一,其基本思想是将要排序的数据按从小到大的顺序排列。具体实现过程如…

    算法与数据结构 2023年5月19日
    00
  • TypeScript实现十大排序算法之归并排序示例详解

    TypeScript实现十大排序算法之归并排序示例详解 简介 本文将详细介绍使用 TypeScript 实现归并排序算法的步骤和示例。归并排序是一种非常有效的排序算法,它的时间复杂度为 O(nlogn),在大多数情况下都比快速排序更加稳定和可靠。 步骤 归并排序是一种典型的分治算法,其基本思路是将待排序的数组不断分割为较小的数组,直到每个小数组只有一个元素,…

    算法与数据结构 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部