Regarder les valeurs binaires imprimées sous forme d'ovales et de bâtons n'est pas si facile ... Pour vous aider, vous devez écrire une fonction (ou un programme) qui imprime des nombres dans une représentation binaire personnalisée.
Je veux donc prendre un nombre, disons 3 ( 00000011
) et sortir les bits dans un format défini par l'utilisateur, par exemple avec des paires séparées par des espaces:
00 00 00 11
ou, par exemple, dans l'ordre inverse et avec certains décorateurs, par exemple:
11_00_00_00
De plus, il doit être possible d'afficher «0» et «1» comme caractères personnalisés pour mieux les distinguer, par exemple:
XX oo oo oo
Le défi consiste donc à écrire le code qui fait tout cela dans la spécification suivante.
spécification
La fonction prend une entrée comme ceci: f (A, masque, zéros, uns)
Paramètres:
A - numéro d'entrée - tout entier (non signé) compris entre 0 et 255.
mask - un paramètre de chaîne qui définit la construction de la sortie.
zéros - une chaîne de même longueur, définit des glyphes «zéro» pour chaque emplacement de sortie.
uns - une chaîne de même longueur, définit des glyphes «un» pour chaque emplacement de sortie.
Règles pour la construction de sortie:
Regardez attentivement cette image avec un exemple pour comprendre comment la sortie est générée:
Ainsi, seuls les chiffres uniques du masque sont analysés et remplacés par les bits correspondants de A, les autres caractères restent tels quels . De plus, si la valeur du bit pris est 1 alors il apparaît dans la sortie finale comme "X" et s'il est 0 alors il apparaît comme "o". Dans l'exemple ci-dessus, les quatre bits pris sont tous "1", nous voyons donc "X" dans tous les emplacements.
Si le numéro d'entrée était 128, alors, logiquement, la sortie serait X foo bar ooo
. Caractères dans les paramètres "zéros" et "uns": tous les caractères ASCII imprimables, supposons qu'ils sont toujours alignés sur le masque.
Remarques :
- Les bits sont indexés 0: le 0e bit est le MSB.
- Supposons que les chiffres 8,9 ne sont pas autorisés dans la chaîne de masque.
- Les chaînes d'entrée incluent tous les caractères ASCII imprimables.
- Les «zéros» et les «uns» sont alignés en caractères avec le masque.
- Pour les caractères spéciaux / modificateurs dans votre langue: nous pouvons supposer qu'ils n'apparaîtront pas dans la chaîne d'entrée.
Pour plus de clarté, voir plus d'exemples.
Entrée -> Exemples de sortie
Sortie tous les 8 bits dans un ordre commun avec un délimiteur d'espace, en notation ovale et bâton commune:
mask = "0123 4567"
zeros = "0000 0000"
ones = "1111 1111"
A=1 -> 0000 0001
Sortie dans l'ordre inverse, en notation tiret et glyphe:
mask = "| 7654 3210 |"
zeros= " ---- ---- "
ones = " ssss ssss "
A=1 -> | s--- ---- |
A=3 -> | ss-- ---- |
A=128-> | ---- ---s |
Diverses notations dans une sortie, par exemple pour les données compressées:
mask = "0 | 123 4567"
zeros= " --- ----"
ones = "X kkk ssss"
A= 15 -> | --- ssss
A= 16 -> | --k ----
A= 32 -> | -k- ----
A= 128 -> X | --- ----
A= 255 -> X | kkk ssss
Modèles répétitifs:
mask = "| 7 66 555 4444 |"
zeros= " . .. ... .... "
ones = " 0 00 000 0000 "
A= 0 -> | . .. ... .... |
A= 1 -> | 0 .. ... .... |
A= 2 -> | . 00 ... .... |
A= 3 -> | 0 00 ... .... |
A= 4 -> | . .. 000 .... |
Mise à jour
Les règles ont été légèrement simplifiées - le programme doit imprimer un seul numéro (pas un tableau / une liste de nombres comme il a été proposé initialement).
A
passe, car c'est la même chose dans tous les cas de test