Maison > développement back-end > Tutoriel Python > Résumé des opérations et calculs décimaux au niveau du bit en Python

Résumé des opérations et calculs décimaux au niveau du bit en Python

高洛峰
Libérer: 2017-03-01 14:14:25
original
1356 Les gens l'ont consulté

Opération AND &

Exemple :
3&5                                                                                                                             Regardons d'abord la place des centaines (en fait, ce n'est pas la place des centaines, c'est juste plus facile à comprendre). un 0 et un 1. D'après (1&1=1, 1&0=0, 0&0=0, 0&1=0), nous savons que la place des centaines devrait être 1, et la place des dizaines est la même. Le nombre 1&0=0, le. nombre dans le chiffre des unités 1&1=1, donc le résultat final est 1. (Il devrait y avoir une étape après cela, car la valeur que nous obtenons maintenant n'est que le complément de la réponse que nous recherchons, mais à cause du nombre positif, le le complément est lui-même, il est donc omis. Cependant, la dernière étape ne peut pas être omise dans l'exemple suivant).
-1&-2
Solution : Le complément de -1 est 11111111, et le complément de -2 est 11111111. 11111111. Le code est 11111110, 11111111&11111110. Le résultat est : 11111110. Il s'agit du code complémentaire. Ensuite, le code d'origine est converti en 100000010 (la méthode de conversion d'un nombre négatif en code d'origine consiste à en soustraire un et à l'annuler). La conversion finale en décimal est -2.
-2&6
Solution : le complément de -2 est 11111110, le complément de 6 est 110, 11111110&110, soit 11111110&00000110 (le but de l'écriture de ceci est de permettre aux débutants de mieux comprendre les opérations au niveau des bits ), suivez la méthode ci-dessus pour obtenir Le résultat est : 110, converti en décimal est 6.
Astuce : Vous pouvez utiliser AND au niveau du bit pour changer le dernier chiffre de n'importe quel nombre binaire en 0, qui est X&0. 🎜>ex :


a = 5
b = 3

print a & b
Copier après la connexion
Résultat : 1

Comment cela est-il calculé ? Il est en fait calculé grâce au système binaire de a et ? b.


# a 的 b 的二进制
# 0*2**3 + 1*2**2 + 0*2**1 + 1*2**0
# 开始与运算
a = 0101
b = 0011
Copier après la connexion
Résultat : 0001

L'opération ET consiste à comparer les nombres binaires de a et b. Si les deux chiffres sont 1, ce sera. compté pour 1. Si vous ne voulez pas être d'accord avec Si les deux sont 0, cela est compté pour 0. Convertissez ensuite la réponse binaire en décimale.


Opération OU|

Exemple : 4|7
Solution : La règle de calcul de l'union au niveau du bit est très similaire à celle du ET au niveau du bit, mais la logique est opérateur modifié, la règle d'union est : 1|1=1,1|0=1, 0|0=0. 4|7 converti en binaire est : 100|111=111 Binaire 111 est 7 en décimal.<🎜. >Conseils : utilisez le bitwise pour changer le dernier chiffre de n'importe quel nombre binaire en 1, qui est X|1.
par exemple :




Résultat : imprimer 7
a = 5
b = 3

print a | b
Copier après la connexion


a | b Le résultat est : 0111
a = 0101
b = 0011
Copier après la connexion
Copier après la connexion
L'opération OU est exactement l'opération ET Au contraire , si le nombre de chiffres n'est pas 0, il est compté pour 1, sinon il est compté pour 0.


Opération OU exclusif

Méthode : Ajout de bits, une attention particulière doit être portée à ne pas porter Solution : 10^101=111, le résultat décimal du binaire 111 est. 7.
1^1Solution : 1 1=0. (À l'origine binaire 1 1=10, mais aucun report n'est autorisé, donc le résultat est 0)
-3^4
Solution : Le complément de -3 est 11111101, le complément de 4 est 100 (c'est-à-dire 00000100), 11111101^00000100=11111101, le complément de 11111101 converti en code d'origine est 1000111, qui est décimal -7.







Résultat : 6 🎜>

a ^ b Le résultat est 0110

Si le nombre de chiffres dans l'opération XOR n'est pas le même , il compte pour 1, sinon il compte pour 0.

a = 5
b = 3

print a ^ b
Copier après la connexion

Décalage vers la gauche et décalage vers la droite

1. Opérateur de décalage vers la gauche <<


Méthode : X<Exemple :

3<<2

Solution : 11 se déplace de deux places vers la gauche pour devenir 1100, ce qui correspond à 12.
a = 0101
b = 0011
Copier après la connexion
Copier après la connexion

2. opération Symbole >>


Méthode : X>>N Déplacer le nombre binaire correspondant à un nombre :11 se déplace de deux places vers la droite et devient 0.

10>>1

Solution : Le nombre binaire de 10 est 1010, et se déplacer d'une place vers la droite est 101, soit 5.




Le résultat est 20 






a << b Résultat : 10100
L'opération de déplacement déplacera le nombre binaire vers la gauche ou vers la droite, comme indiqué ci-dessus, il se déplace de 2 unités vers la gauche.

Pour plus d'articles liés au résumé des opérations et calculs décimaux au niveau du bit en Python, veuillez faire attention au site Web PHP chinois !

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal