全排列

简介: 全排列,

全排列

  1. 字符串参数中的字符无重复且仅包含小写字母
  2. 返回的排列组合数组不区分顺序
const _permute = string => {
   
  if (string.length === 1) {
   
    return [string];
  }
  const res = [];
  for (let s of string) {
   
    const arr = string.split('').filter(str => str !== s);
    _permute(arr.join('')).forEach(item => {
   
      res.push(s + item);
    });
  }
  return res;
};
const input = 'abc';
const result = _permute(input);
console.log(result);

这段代码是一个递归函数 _permute,用于生成字符串参数的所有排列组合。它使用了回溯法的思想。

首先,如果字符串的长度为 1,表示已经无法再进行排列,直接返回包含该字符串的数组 [string]。

否则,创建一个空数组 res,然后对字符串中的每个字符 s 进行遍历。在每次遍历中,生成一个新的数组 arr,其中排除当前字符
s。接着,递归调用 _permute 函数,传入 arr.join('') 作为新的字符串参数,获取其排列组合结果。

对于递归返回的每个排列组合 item,将当前字符 s 与 item 拼接,并将结果添加到 res 数组中。

最后,函数返回所有排列组合的结果数组 res。

目录
相关文章
|
1月前
|
Java
leetcode-46:全排列
leetcode-46:全排列
25 1
|
1月前
|
存储
全排列问题
全排列问题
|
11月前
|
C++
1199:全排列
1199:全排列
127 0
|
1月前
|
Java
leetcode-47:全排列 II
leetcode-47:全排列 II
23 0
|
10月前
|
机器学习/深度学习 存储 算法
算法训练Day29|* 491.递增子序列* 46.全排列* 47.全排列 II
算法训练Day29|* 491.递增子序列* 46.全排列* 47.全排列 II
|
12月前
|
机器学习/深度学习 算法 安全
LeetCode - #47 全排列 II
不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。
leetcode:46.全排列
给定一个没有重复数字的序列,返回其所有可能的全排列。
37 0
leetcode:47.全排列 II
给定一个可包含重复数字的序列,返回所有不重复的全排列。
37 0

热门文章

最新文章