Reto:
Dada una matriz de entrada cuadrada A , rellene la matriz con una fila y una columna en los cuatro lados.
- El valor de cada elemento en la fila superior e inferior debe ser la suma de los elementos en cada columna correspondiente.
- El valor de cada elemento en la columna izquierda y derecha debe ser la suma de los elementos en cada fila correspondiente.
- El valor de los elementos en la esquina superior izquierda e inferior derecha debe ser la suma de los elementos en diagonal
- El valor de los elementos en la esquina superior derecha y en la esquina inferior izquierda debe ser la suma de los elementos en el anti-diagonal.
Ejemplo:
A =
1 5 3
3 2 4
2 5 5
Output:
8 6 12 12 7
9 1 5 3 9
9 3 2 4 9
12 2 5 5 12
7 6 12 12 8
Explicación:
Los elementos superior izquierdo e inferior derecho son la suma de la diagonal 1 + 2 + 5 = 8 . Los elementos superior derecho e inferior izquierdo son la suma del antia diagonal 2 + 2 + 3 = 7 .
La fila superior e inferior (excepto las esquinas) son la suma de cada una de las columnas en A : 1 + 3 + 2 = 6 , 5 + 2 + 5 = 12 y 3 + 4 + 5 = 12 . Del mismo modo, la columna izquierda y derecha (excepto las esquinas) son la suma de cada una de las filas de A : 1 + 5 + 3 = 9 , 3 + 2 + 4 = 9 y 2 + 5 + 5 = 12 .
Entrada:
- Una matriz cuadrada no vacía, con enteros no negativos.
- Formato opcional
Salida:
- La matriz acolchada como se explicó anteriormente
- Formato opcional, pero debe ser el mismo que el formato de entrada
Casos de prueba:
Utilice las presentaciones en este desafío si desea convertir el formato de entrada a uno más adecuado (por ejemplo [[1, 5],[0, 2]]
).
0
----------------
0 0 0
0 0 0
0 0 0
1 5
0 2
----------------
3 1 7 5
6 1 5 6
2 0 2 2
5 1 7 3
17 24 1 8 15
23 5 7 14 16
4 6 13 20 22
10 12 19 21 3
11 18 25 2 9
----------------
65 65 65 65 65 65 65
65 17 24 1 8 15 65
65 23 5 7 14 16 65
65 4 6 13 20 22 65
65 10 12 19 21 3 65
65 11 18 25 2 9 65
65 65 65 65 65 65 65
15 1 2 12
4 10 9 7
8 6 5 11
3 13 14 0
----------------
30 30 30 30 30 30
30 15 1 2 12 30
30 4 10 9 7 30
30 8 6 5 11 30
30 3 13 14 0 30
30 30 30 30 30 30
Este es el código de golf , por lo que gana la solución más corta en cada idioma . Las explicaciones son altamente alentadas.