Maison >interface Web >js tutoriel >Question amusante JavaScript : binaire statistique

Question amusante JavaScript : binaire statistique

黄舟
黄舟original
2017-02-13 16:23:451419parcourir

Ceux qui travaillent sur le front-end doivent avoir peu d'occasions d'entrer en contact avec le binaire. Ces opérations sur les bits ne sont-elles pas quelque chose que la couche inférieure devrait prendre en compte ?

J'ai vu une question hier. Elle était liée au binaire, mais peu importe que des opérations sur les bits soient utilisées ou non, elle pouvait être facilement résolue à l'aide des fonctionnalités du langage JS.

est décrit comme suit :

Écrivez une fonction qui reçoit un entier décimal positif en paramètre, le représente en binaire et renvoie le nombre dont les chiffres sont égaux à 1.

Par exemple :

1234 exprimé en binaire vaut 1001101 00 10, il y en a 51, donc 5 est renvoyé.

Après avoir lu cette description, la première chose qui m'est venue à l'esprit c'est que le professeur m'apprenait à convertir du décimal en binaire (ce sera plus facile d'utiliser le livre ^_^) .

Heureusement, j'ai une bonne mémoire, et j'y ai vite pensé. Pour cet entier positif, prenez d'abord le reste de 2, puis divisez-le par 2. , puis vérifiez le résultat Prenez le reste de 2 et divisez-le par 2... jusqu'à ce que le résultat soit 0.

Ensuite, dans le processus ci-dessus, utilisez une variable pour enregistrer le nombre de fois où le reste est 1, et enfin revenez.

Nous avons donc proposé l'approche suivante :


var countBits = function(n) {
    var count = 0;
    while(n > 0){
        var res = n % 2;
        if(res == 1){
            count++;
        }
        n = parseInt(n / 2);
    }
    return count;
};

Ce code et cette idée sont tout à fait satisfaisants, mais ils n'utilisent pas pleinement le fonctionnalités linguistiques de JS.

N'existe-t-il pas une API prête à l'emploi pour convertir le décimal en binaire en JS ?

number.toString(2), cela n'obtient-il pas une chaîne binaire ?

Les résultats sont tous sortis, puis recherchez le chiffre 1 un par un, puis revenez.

Hmm, les deux méthodes ci-dessus sont bonnes, mais elles mènent au même objectif, et la méthode la plus efficace est l'opération sur bits.

Enfin, jetons un coup d’œil à une solution de fonctionnement écrite par un expert étranger !


function countBits(n) {
  for(c=0;n;n>>=1)c+=n&1
  return c;
}

Tsk, tsk, le rythme qui rend les yeux aveugles.

Ce qui précède est une question JavaScript intéressante : contenu binaire statistique. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn