Carré magique

Un carré magique est une grille carrée dans laquelle des nombres sont placés de telle sorte que la somme des nombres de chaque colonne, chaque ligne et de chacune des deux diagonales soit la même. De plus, Le carré doit contenir une fois chaque nombre, de 1 au nombre de cases de la grille.

Ecrivez un programme qui vérifie si une grille de nombres est un carré magique.

Limites de temps et de mémoire (Python)

  • Temps : 1 s sur une machine à 1 GHz.
  • Mémoire : 1 000 ko.

Contraintes

  • 1 <= N <= 20, où N est le nombre de lignes et de colonnes de la grille.

Entrée

La première ligne de l'entrée contient un entier N : le nombre de cases du côté de la grille de nombres.

Chacune des N lignes suivantes contient N entiers séparés par des espaces : les nombres d'une ligne de la grille.

Sortie

Vous devez afficher une ligne sur la sortie, contenant le mot "yes" si le carré fourni est un carré magique, et "no" sinon.

Exemple

entrée :

3
6 1 8
7 5 3
2 9 4

sortie :

yes

Commentaires

Chacun des chiffres de 1 à 9 apparaît exactement une fois dans la grille. De plus, toutes les colonnes, lignes et les deux diagonales de cette grille ont pour somme 15. En effet :

Lignes :
6 + 1 + 8 = 15
7 + 5 + 3 = 15
2 + 9 + 4 = 15

Colonnes :
6 + 7 + 2 = 15
1 + 5 + 9 = 15
8 + 3 + 4 = 15

Diagonales :
6 + 5 + 4 = 15
8 + 5 + 2 = 15


Source : https://www.france-ioi.org/ Créé par : Mathias Hiron.