gpt4 book ai didi

javascript - 生成所有可能的字符串组合

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:47:07 26 4
gpt4 key购买 nike

我正在尝试生成字符串的所有可能组合。

例如对于下面的列表:a1q5z!H9, b1q5z!H9, c1q5z!H9, d1q5z!H9, a2q5z!H9 ...等

与其制作大量嵌套循环,我想我会尝试使用 MODULO 做一些聪明的事情……但是碰壁了。

这是我想出的 Javascript - 任何关于我如何继续的指示?

var c = [
['a', 'b', 'c', 'd'],
['1', '2', '3', '4'],
['q', 'w', 'e', 'r'],
['5', '6', '7', '8'],
['z', 'x', 'c', 'v'],
['!', '"', '£', '$'],
['H', 'J', 'K', 'L'],
['9', '8', '7', '6'],
];

var o = document.getElementById('output');
var pw = "";
var chars = c.length;

for( var i = 0; i <20; i++)
{
pw = ""
for(var j = 0; j < chars; j++ )
{
pw += c[j][i%4];
}
op(pw);
}

function op(s)
{
o.innerHTML = o.innerHTML + "<br>" + s;
}

这只输出列表中的前 20 个,但会重复……我几乎有,但不完全。任何帮助或指点表示赞赏。

最佳答案

写一个递归函数很容易demo .

function permutate(abc, memo) {
var options;
memo = memo || abc.shift().slice(0);

if(abc.length) {
options = abc.shift();

return permutate(abc, memo.reduce(function(all, item){
return all.concat(options.map(function(option){
return item + option;
}))
}, []));
}

return memo;
};

console.log(permutate(c).length); //65536 items

或者更命令式的方式

function permutate2(abc) {
var options, i, len, tmp, j, optionsLen,
memo = abc.pop().slice(0); //copy first the last array

while(options = abc.pop()) { //replace recursion
tmp = [];
optionsLen = options.length;
for(i = 0, len = memo.length; i < len; i++) { //for every element in memo
for(j = 0; j < optionsLen; j++) { //do cartesian product with options
tmp.push(options[j] + memo[i]);
}
}
memo = tmp;
}

return memo;
}

关于javascript - 生成所有可能的字符串组合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24387939/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com