在 JavaScript 中创建字符串的所有可能的唯一排列
问题
我们需要编写一个接受字符串str的JavaScript函数。我们的函数应该创建输入字符串的所有排列并删除重复项(如果存在)。这意味着,我们必须以所有可能的顺序打乱输入中的所有字母。
示例
以下是代码-
const str = 'aabb';
const permute = (str = '') => {
if (!!str.length &&str.length< 2 ){
return str
}
const arr = [];
for (let i = 0; i < str.length; i++){
let char = str[i]
if (str.indexOf(char) != i)
continue
let remainder = str.slice(0, i) + str.slice(i + 1, str.length)
for (let permutation of permute(remainder)){
arr.push(char + permutation)
}
}
return arr
}
console.log(permute(str));输出结果以下是控制台输出-
[ 'aabb', 'abab', 'abba', 'baab', 'baba', 'bbaa' ]
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短