Ir al contenido (saltar navegación)

Cuadrados diabólicos y esotéricos

Tiempo máximo: 4,000 sMemoria máxima: 10240 KiB

Se considera un cuadrado mágico diabolico a la disposición de una serie de números enteros en un cuadrado de forma tal que la suma de los números por columna, fila y diagonales principales sea la misma. A esta suma se le llama constante mágica (CM). Para nuestro desarrollo consideraremos el cuadrado como una matriz con igual número de filas que de columnas.

Si suponemos n la cantidad de filas o columnas del cuadrado, un cuadrado mágico diabólico es esotérico cuando, además de ser diabólico, cumple las siguientes condiciones:

  1. Tiene las mismas cifras que el número de casillas. Es decir, siguen la serie de números naturales de 1 a n².
  2. La suma de sus esquinas debe ser la constante mágica 2 (CM2) que cumple que:
  3. \[CM2 = \frac{4 \cdot CM}{n}\]
  4. Si n es impar:
    • La suma de las cifras de las cuatro casillas de la mitad de los laterales suman la constante mágica 2.
    • Si se multiplica el valor de la casilla central por 4, se obtiene la constante mágica 2.
    2247164110354
    5234817421129
    3062449183612
    1331725431937
    3814321264420
    213983322745
    461540934328
    n = 7
    Constante mágica = 175
    Constante mágica 2 = 100
    Esquinas22 + 4 + 46 + 28 = 100 (CM2)
    Centro4 · 25 = 100 (CM2)
    Centro lados41 + 13 + 37 + 9 = 100 (CM2)
  5. Si n es par:
    • La suma de las dos casillas centrales de cada uno de los cuatro laterales suman el doble de la constante mágica 2 (2 · CM2)
    • La suma de las cuatro casillas centrales da como resultado la constante mágica 2.
163624559588
5610115352141549
4818194544222341
2539382829353432
3331303637272640
2442432120464717
165051131254559
577660613264
n = 8
Constante mágica = 260
Constante mágica 2 = 130
Esquinas1 + 8 + 57 + 64 = 130 (CM2)
Centro28 + 29 + 36 + 37 = 130 (CM2)
Centro lados4 + 5 + 25+ 33 + 60 + 61 + 32 + 40
= 260 (2 · CM2)

Entrada

El programa leerá de la entrada estándar un cuadrado mágico tras otro. Cada cuadrado mágico consistirá en dos líneas. La primera línea contendrá el valor de n (2 ≤ n ≤ 1024). La segunda línea será los valores de las n² celdas, uno detrás de otro.

La entrada termina cuando al leer el tamaño del siguiente cuadrado mágico se recibe un 0.

Salida

Para un cuadrado esotérico, el programa escribirá ESOTERICO, para un cuadrado mágico diabólico (no esotérico) escribirá DIABOLICO. Para cualquier otro cuadrado, mostrará NO.

Entrada de ejemplo

3
4 9 2 3 5 7 8 1 6
2
1 2 3 4
4
16 3 2 13 5 10 11 8 9 6 7 12 4 15 14 1
3
28 21 26 23 25 27 24 29 22
3
2 8 1 6 3 5 7 4 9 
0

Salida de ejemplo

ESOTERICO
NO
ESOTERICO
DIABOLICO
NO