js实现简单排列组合的方法

下面是详细讲解 "js实现简单排列组合的方法" 的攻略。

排列组合的概念

排列就是由给定的n个元素中取出m(m ≤ n)个元素的所有排列总数的不同的排列数,用A(n, m)表示。例如,有3个元素A、B、C,则它们的排列有:ABC、ACB、BAC、BCA、CAB、CBA,共6种排列。

组合是指从n个不同元素中,取出m(m≤n)个元素的所有组合情况,用C(n,m)表示。

排列算法实现

以下是一个生成一个序列中所有排列的JavaScript函数:

function generatePerm(arr) { 
    var permutations = [], 
        usedChars = []; 
    function permute(arr) { 
        var i, ch; 
        for (i = 0; i < arr.length; i++) { 
            ch = arr.splice(i, 1)[0]; 
            usedChars.push(ch); 
            if (arr.length === 0) { 
                permutations.push(usedChars.slice());  
            } 
            permute(arr); 
            arr.splice(i, 0, ch); 
            usedChars.pop(); 
        } 
        return permutations; 
    } 
    return permute(arr); 
} 

使用方法

var arr = [1, 2, 3]; 
console.log(generatePerm(arr));

输出:

[[1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1], [3, 1, 2], [3, 2, 1]] 

以上算法中,使用一个递归函数permute,将数组中的每个元素当作起始元素,以此生成不同的排列。

组合算法实现

以下是一个生成一个序列中所有组合的JavaScript函数:

function generateComb(arr, numElements) { 
    var results = [], 
        result = []; 
    function combine(arr, numElements, pos) { 
        if (result.length === numElements) { 
            results.push(result.slice()); 
            return; 
        } 
        for (var i = pos; i < arr.length; i++) { 
            result.push(arr[i]); 
            combine(arr, numElements, i+1); 
            result.pop(); 
        } 
    } 
    combine(arr, numElements, 0); 
    return results; 
} 

使用方法:

var arr = [1, 2, 3]; 
console.log(generateComb(arr, 2));

输出:

[[1, 2], [1, 3], [2, 3]] 

以上算法中,使用一个递归函数combine,从数组的第一个元素开始,逐个把元素加入结果数组,如果元素加满了,就把该组合加入结果集。如果还没加满,就继续往后递归。需要注意的是,递归时的pos参数表示起始位置,要逐个枚举数组中剩余的元素。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js实现简单排列组合的方法 - Python技术站

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

相关文章

  • C语言排序算法之插入排序

    让我来详细讲解一下“C语言排序算法之插入排序”的完整攻略。 什么是插入排序? 插入排序是一种简单的排序算法,其原理是将一个数组分为两个部分,已排序和未排序。通过一次次取出未排序部分的首位元素,插入到已排序部分中正确的位置,最终实现整个数组的排序。 插入排序算法的步骤 插入排序的具体步骤如下: 将待排序数组分成已排序和未排序两个部分,第一个元素默认为已排序部分…

    算法与数据结构 2023年5月19日
    00
  • 使用C语言求解扑克牌的顺子及n个骰子的点数问题

    “使用C语言求解扑克牌的顺子及n个骰子的点数问题”,我们可以分别来看一下。 1. 求解扑克牌的顺子 首先我们需要了解什么是扑克牌的顺子,即五张连续的牌,如”10 J Q K A”等。因为一副牌里,最小的牌为2,最大的牌为A(即1),所以任何5张牌中最大和最小的差值不能超过4。 我们可以先将5张牌进行排序,然后用最大牌和最小牌计算差值,再去除所有大小王,如果差…

    算法与数据结构 2023年5月19日
    00
  • C语言深入探究直接插入排序与希尔排序使用案例讲解

    C语言深入探究直接插入排序与希尔排序使用案例讲解 直接插入排序 算法描述 直接插入排序的基本思想是将一个记录插入到已经排序好的有序表中,从而得到一个新的、记录数增加1的有序表。具体算法流程如下: 从第一个元素开始,该元素可以认为已经被排序 取出下一个元素,在已经排序的元素序列中从后向前扫描 如果该元素大于新元素,将该元素移到下一位置 重复步骤3,直到找到已排…

    算法与数据结构 2023年5月19日
    00
  • java插入排序 Insert sort实例

    下面我将详细讲解如何实现Java的插入排序算法。 插入排序 Insert Sort 插入排序是一种简单直观的排序算法,它的基本思想是将未排序的数据依次插入到已排序数据中的合适位置,使得插入后序列仍然有序。 插入排序的算法步骤如下: 从第一个元素开始,该元素可以认为已经被排序; 取出下一个元素,在已经排序的元素序列中从后向前扫描; 如果该元素(已排序)大于新元…

    算法与数据结构 2023年5月19日
    00
  • 快速排序算法在Swift编程中的几种代码实现示例

    让我为您详细讲解“快速排序算法在Swift编程中的几种代码实现示例”的完整攻略。 快速排序算法简介 快速排序是一种常用的排序算法,其基本思想是通过一个枢轴(pivot)将待排序数组分成两个部分,一部分小于枢轴,一部分大于枢轴,然后对这两个部分进行递归排序,最终得到一个有序的数组。 快速排序算法实现 下面是三种在Swift编程中实现快速排序算法的代码示例。 代…

    算法与数据结构 2023年5月19日
    00
  • JS使用队列对数组排列,基数排序算法示例

    JS使用队列对数组进行排序,可以使用基数排序算法。 基数排序算法是一种非比较排序算法,通过将待排序数据按照位数切割成个、十、百、千等位,然后从低位依次向高位对每个位数进行排序。基数排序算法在排序过程中使用了队列数据结构来保存临时排序结果。 以下是基数排序算法的JavaScript实现: function radixSort(array) { const ma…

    算法与数据结构 2023年5月19日
    00
  • java排序算法图文详解

    Java排序算法图文详解 在Java编程中,排序算法是非常重要且常见的一部分。本文将详细讲解Java中的各种排序算法及其实现,帮助读者了解不同算法的特点和使用场景,提高程序的效率和可读性。 排序算法分类 在Java中,常用的排序算法主要可以分为以下几类: 冒泡排序 选择排序 插入排序 快速排序 归并排序 堆排序 冒泡排序 冒泡排序是一种简单的排序算法,其原理…

    算法与数据结构 2023年5月19日
    00
  • PHP字符串逆序排列实现方法小结【strrev函数,二分法,循环法,递归法】

    下面我将为您详细讲解“PHP字符串逆序排列实现方法小结【strrev函数,二分法,循环法,递归法】”的完整攻略。 什么是字符串逆序排列? 字符串逆序排列指的是将一个字符串中的字符按照相反的顺序重新排列,比如将字符串 “hello world” 更改为 “dlrow olleh”。 使用strrev函数实现字符串逆序排列 PHP内置函数 strrev() 可以…

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