00:00 0
Dans cet exercice, on appelle carré d’ordre 𝑛 un tableau de 𝑛 lignes et 𝑛 colonnes dont chaque case contient un entier naturel. Exemples : | Carré | d'ordre 2 |&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; | Carré | d'ordre 3 | | &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; | | Carré | d'ordre 4 | | |:-------:|:-----------:|:-----------:|:-------:|:-----------:|:---:|:-----------:|:----:|:-------:|:-----------:|:----:| | 1 | 1 | | 2 | 9 | 4 | | 4 | 5 | 16 | 9 | | 1 | 1 | | 7 | 5 | 3 | | 14 | 7 | 2 | 11 | | | c2 | | 6 | 1 | 8 | | 3 | 10 | 15 | 6 | | | | | | c3 | | | 13 | 12 | 8 | 1 | | | | | | | | | | c4 | | | Un carré est dit magique lorsque les sommes des éléments situés sur chaque ligne, chaque colonne et chaque diagonale sont égales. Ainsi c2 et c3 sont magiques car la somme de chaque ligne, chaque colonne et chaque diagonale est égale à 2 pour c2 et 15 pour c3. c4 n’est pas magique car la somme de la première ligne est égale à 34 alors que celle de la dernière colonne est égale à 27. La classe <code>Carre</code> ci-après contient des méthodes qui permettent de manipuler des carrés. Compléter la fonction <code>est_magique</code> qui prend en paramètre un carré et qui renvoie la valeur de la somme si ce carré est magique, <code>False</code> sinon.
class Carre: def __init__(self, tableau = [[]]): self.ordre = len(tableau) self.valeurs = tableau def affiche(self): '''Affiche un carré''' for i in range(self.ordre): print(self.valeurs[i]) def somme_ligne(self, i): '''Calcule la somme des valeurs de la ligne i''' return sum(self.valeurs[i]) def somme_col(self, j): '''calcule la somme des valeurs de la colonne j''' return sum([self.valeurs[i][j] for i in range(self.ordre)]) #################### Ne pas modifier ce qui precede ##################### def est_magique(carre): n = carre.ordre s = carre.somme_ligne(0) #test de la somme de chaque ligne for i in range(..., ...): if carre.somme_ligne(i) != s: return ... #test de la somme de chaque colonne for j in range(n): if ... != s: return False #test de la somme de chaque diagonale if sum([carre.valeurs[...][...] for k in range(n)]) != s: return False if sum([carre.valeurs[k][n-1-k] for k in range(n)]) != s: return False return ...
Test 1
Test 2
Test 3
Console

			
Sortie