admin管理员组文章数量:1333386
I am trying to generate all possible binations of a string.
e.g. for the list below: a1q5z!H9, b1q5z!H9, c1q5z!H9, d1q5z!H9, a2q5z!H9 ... etc
Rather than make lots of nested loops, I thought I would try something clever with MODULO ... but hit a wall.
This is the Javascript I have e up with - any pointers to how I might go on?
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;
}
This just outputs the first 20 in the list, but repeats ... I nearly have it but not quite. Any help or pointers appreciated.
I am trying to generate all possible binations of a string.
e.g. for the list below: a1q5z!H9, b1q5z!H9, c1q5z!H9, d1q5z!H9, a2q5z!H9 ... etc
Rather than make lots of nested loops, I thought I would try something clever with MODULO ... but hit a wall.
This is the Javascript I have e up with - any pointers to how I might go on?
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;
}
This just outputs the first 20 in the list, but repeats ... I nearly have it but not quite. Any help or pointers appreciated.
Share Improve this question edited Jun 24, 2014 at 13:58 Ruskin asked Jun 24, 2014 at 13:29 RuskinRuskin 6,1714 gold badges49 silver badges65 bronze badges 6-
Why is
c
structured like that? – Cerbrus Commented Jun 24, 2014 at 13:30 - and I know string concatenation is not the most efficient, but this is quick and dirty code - not optimised. – Ruskin Commented Jun 24, 2014 at 13:30
- Quick and dirty array of chars - first thing that came to mind. Data is meaninless - just random chars – Ruskin Commented Jun 24, 2014 at 13:33
- The length of the string has an importance, or "ab2" is a valid result too? – Nicolas Henrard Commented Jun 24, 2014 at 13:38
- Yea, but why is it an array of arrays of chars? Why the nested array? – Cerbrus Commented Jun 24, 2014 at 13:41
3 Answers
Reset to default 6Quite easy to write a recursive function 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
Or more imperative approach
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;
}
function binations(str) {
debugger;
var arr = [];
for (var i = 0; i < str.length; i++)
{
// create an empty string
var b = "";
// loop for substring
for (var j = i; j < str.length; j++)
{
b+=str[j];
arr.push(b);
}
}
return arr;
}
console.log(binations('output'));
This is how I did it:
string password;
bool done = false;
while (!done) {
password = string.Empty;
for(int a = 0; a < blah[0].Length; a++) {
for(int b = 0; b < blah[1].Length; b++) {
for (int c = 0; c < blah[2].Length; c++) {
for (int d= 0; d < blah[3].Length; d++) {
for (int e = 0; e < blah[4].Length; e++) {
for (int f = 0; f < blah[5].Length; f++) {
for (int g = 0; g < blah[6].Length; g++) {
for (int h = 0; h < blah[7].Length; h++) {
password = string.Format(
"{0}{1}{2}{3}{4}{5}{6}{7}",
blah[0][a],
blah[1][b],
blah[2][c],
blah[3][d],
blah[4][e],
blah[5][f],
blah[6][g],
blah[7][h]);
Console.Out.WriteLine(password);
}
}
}
}
}
}
}
}
}
Where blah is the character matrix.
Ugly, granted, but the shorter answer by Yury hurts my head.
本文标签: javascriptGenerating all possible combinations of stringsStack Overflow
版权声明:本文标题:javascript - Generating all possible combinations of strings - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1742331974a2454876.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论