JS функция для написания слова, стиль двоичного счетчика - PullRequest
1 голос
/ 24 февраля 2010

Как я могу создать цикл для вывода любого данного слова, как это:

... если слово '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

и т.д.

Спасибо

Ответы [ 5 ]

6 голосов
/ 24 февраля 2010
var i = 1;
console.log("abcd".replace(/./g, function(c,n) { 
   return (i & (1 << n)) ? c : '-';
}));

Just loop i от 1 до (2 ^ length) -1

1 голос
/ 24 февраля 2010
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");
1 голос
/ 24 февраля 2010

Похоже, вы действительно хотите изменить счет двоичных чисел; то есть для двоичного файла это будет

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("");
}
0 голосов
/ 24 февраля 2010

Вот краткая версия:

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);
}

Наслаждайтесь!

0 голосов
/ 24 февраля 2010

с кодом 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>');
}

это было весело :) Для чего тебе это нужно?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...