PROBLEME
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.
CONTRAINTES
1 <= N <= 20, où N est le nombre de lignes et de colonnes de la grille.
ENTREE
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.
CODE SOURCE
Code: C++ #include <cstdio> template <size_t size> bool is_magic(unsigned int N, unsigned int (&grille)[size][size]) { for (unsigned int i=1; i<=N; i++) { unsigned int nb = 0; for (unsigned int x=0; x<N; x++) for (unsigned int y=0; y<N; y++) if (grille[x][y] == i) nb++; if (nb != 1) return false; } unsigned int sum = 0; for (int i=0; i<N; i++) sum += grille[0][i]; for (unsigned int i=0; i<N; i++) { unsigned int n = 0; for (unsigned int j=0; j<N; j++) n += grille[i][j]; if (n != sum) return false; } for (unsigned int i=0; i<N; i++) { unsigned int n = 0; for (unsigned int j=0; j<N; j++) n += grille[j][i]; if (n != sum) return false; } { unsigned int n = 0; for (unsigned int i=0; i<N; i++) n += grille[i][i]; if (n != sum) return false; } { unsigned int n = 0; for (unsigned int i=0; i<N; i++) n += grille[N-1-i][i]; if (n != sum) return false; } return true; } int main(int argc, char* argv[]) { unsigned int N; scanf_s("%u", &N); unsigned int grille[20][20]; for (unsigned int y=0; y<N; y++) for (unsigned int x=0; x<N; x++) scanf_s("%u", &grille[x][y]); if (is_magic(N, grille)) printf("yes\n"); else printf("no\n"); return 0; }
|