如何创建一个循环来输出任何给定的单词,如下所示:
......如果这个词是'abcd'
a---
-b--
ab--
--c-
a-c-
-bc-
abc-
---d
a--d
-b-d
ab-d
--cd
a-cd
-bcd
abcd
换句话说,字母以二进制计数器顺序出现
1000
0100
1100
0010
1010
等
由于
答案 0 :(得分:6)
var i = 1;
console.log("abcd".replace(/./g, function(c,n) {
return (i & (1 << n)) ? c : '-';
}));
从i
到1
(2 ^ length) -1
答案 1 :(得分:1)
看起来你真的想要二进制计数的逆转;即对于二进制,它将是
0001
0010
0011
但是你正在翻转它。哪个好。下面的代码从0到必要的数字(四个字母的单词为16),得到每个数字的二进制表示,反转它,并为二进制表示中有一个的那些地方输出单词的字母。
function letterScroller(str) {
var iterations = Math.pow(2,str.length);//iterate from 0 to 2**wordlength
var result = "";
for (i=0;i<iterations;i++) {
//get the binary representation, pad it, and reverse it
var bin = reverse(pad(i.toString(2), str.length));
//loop through binary, adding character of word where there's a 1
for (j=0;j<str.length;j++) {
if (bin.charAt(j)=="1") {
result += str.charAt(j)
} else {
result += "-";
}
}
result += "<br />"; //separate lines with HTML line break
}
return result;
}
function pad(str, length) {
while (str.length < length) {
str="0" + str;
}
return str;
}
function reverse (str) {
return str.split("").reverse().join("");
}
答案 2 :(得分:1)
function doStuff(word) {
var wordLength = word.length, num = 1 << wordLength;
var i, bit, wordChars = word.split(""), chars;
for (var i = 1; i < num; ++i) {
chars = [];
for (bit = 0; bit < wordLength; ++bit) {
chars.push( i & 1 << bit ? wordChars[bit] : "-" );
}
console.log( chars.join("") );
}
}
doStuff("abcd");
答案 3 :(得分:0)
使用KennyTM的代码可以很容易地完成
String.prototype.reverse = function(){
splitext = this.split("");
revertext = splitext.reverse();
reversed = revertext.join("");
return reversed;
}
str='abcd'; //your string
for(var i=0;i<20;i++){ //a loop of numbers
var result='';
var ii=i.toString(2).reverse();
for(var q=0;q<Math.max(ii.length,str.length);q++){
if(ii.charAt(q)=='1'){
result+=str.charAt(q);
}else{
result+='-';
}
}
document.write(result+'<br>');
}
那很有趣:)
你需要什么?
答案 4 :(得分:0)
以下是简短版本:
var string = 'abcd';
for (i = 1; i < Math.pow(string.length,2); i++) {
str = "";
for (j = 0; j < string.length; j++) {
if (i & (1 << j))
str += string[j];
else
str += "-";
}
console.log(str);
}
享受!