CODE PUZZLE

[EP24] - 19.2
On affecte à chaque lettre de l'alphabet un code selon le tableau ci-dessous : | A | B | C | D | E | F | G | H | I | J | K | L | M | |:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:| | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | | N | O | P | Q | R | S | T | U | V | W | X | Y | Z | |:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:| | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | Cette table de correspondance est stockée dans un dictionnaire `dico` où les clés sont les lettres de l’alphabet et les valeurs les codes correspondants. ``` dico = {"A": 1, "B": 2, "C": 3, "D": 4, "E": 5, "F": 6, "G": 7, "H": 8, "I": 9, "J": 10, "K": 11, "L": 12, "M": 13, "N": 14, "O": 15, "P": 16, "Q": 17, "R": 18, "S": 19, "T": 20, "U": 21, "V": 22, "W": 23, "X": 24, "Y": 25, "Z": 26} ``` Pour un mot donné, on détermine d’une part son code ***alphabétique concaténé***, obtenu par la juxtaposition des codes de chacun de ses caractères, et d’autre part, ***son code additionné***, qui est la somme des codes de chacun de ses caractères. Par ailleurs, on dit que ce mot est « ***parfait*** » si le code additionné divise le code concaténé. Exemples : * Pour le mot `"PAUL"`, le code concaténé est la chaîne `'1612112'`, soit l’entier `1612112`. Son code additionné est l’entier `50` car `16 + 1 + 21 + 12 = 50`. `50` ne divise pas l’entier `1612112` ; par conséquent, le mot `"PAUL"` n’est pas parfait. * Pour le mot `"ALAIN"`, le code concaténé est la chaîne `'1121914'`, soit l’entier `1121914`. Le code additionné est l’entier `37` car `1 + 12 + 1 + 9 + 14 = 37`. `37` divise l’entier `1121914` ; par conséquent, le mot `"ALAIN"` est parfait. Compléter la fonction `codes_parfait` située à la page suivante et qui prend en paramètre un mot en majuscule et renvoie un triplet constitué du code additionné, du code concaténé et d’un booléen indiquant si le mot est parfait ou non. On rappelle que pour tester si un entier `a` divise un entier `b`, on utilise l’opérateur modulo `b % a` qui renvoie le reste de la division euclidienne de `b` par `a`. Si `b % a` vaut `0`, alors a divise `b`. ``` def codes_parfait(mot): """Renvoie un triplet (code_additionne, code_concatene, mot_est_parfait) où : - code_additionne est la somme des codes des lettres du mot ; - code_concatene est le code des lettres du mot concaténées ; - mot_est_parfait est un booléen indiquant si le mot est parfait.""" code_concatene = "" code_additionne = ... for c in mot: code_concatene = code_concatene + ... code_additionne = code_additionne + ... code_concatene = int(code_concatene) mot_est_parfait = ... return code_additionne, code_concatene, mot_est_parfait ``` Exemples : ``` >>> codes_parfait("PAUL") (50, 1612112, False) >>> codes_parfait("ALAIN") (37, 1121914, True) ```
def codes_parfait(mot): """Renvoie un triplet (code_additionne, code_concatene, mot_est_parfait) où : - code_additionne est la somme des codes des lettres du mot ; - code_concatene est le code des lettres du mot concaténées ; - mot_est_parfait est un booléen indiquant si le mot est parfait.""" code_concatene = "" code_additionne = ... for c in mot: code_concatene = code_concatene + ... code_additionne = code_additionne + ... code_concatene = int(code_concatene) mot_est_parfait = ... return code_additionne, code_concatene, mot_est_parfait
Test 1
Test 2
Console

			
Sortie