█████████ ████ ███░░░░░███ ░░███ ███ ░░░ ██████ ███████ ██████ ██████ ░███ ███░░███ ███░░███ ███░░███ ███░░███ ░███ ░███ ░███░███ ░███ ░███████ ░███ ░███ ░░███ ███░███ ░███░███ ░███ ░███░░░ ░███ ░███ ░░█████████ ░░██████ ░░████████░░██████ ░░██████ ░░░░░░░░░ ░░░░░░ ░░░░░░░░ ░░░░░░ ░░░░░░

Envío 897

Problema 0xe1 - Cuadrado mágico

  • Autor: davidtoca
  • Fecha: 2020-09-27 21:29:23 UTC (Hace más de 3 años)
Caso # Resultado Tiempo Memoria
#1
Correcto
0.005 s 1 KBi
#2
Correcto
0.005 s 1 KBi
#3
Correcto
0.005 s 1 KBi
#4
Correcto
0.005 s 1 KBi
#5
Correcto
0.005 s 1 KBi
#6
Correcto
0.005 s 1 KBi
#7
Correcto
0.005 s 1 KBi
#8
Correcto
0.005 s 1 KBi
#9
Correcto
0.005 s 1 KBi
#10
Correcto
0.005 s 5 KBi
#11
Correcto
0.005 s 1 KBi
#12
Correcto
0.006 s 1 KBi
#13
Correcto
0.005 s 1 KBi
#14
Correcto
0.005 s 1 KBi
#15
Correcto
0.005 s 1 KBi
#16
Correcto
0.008 s 1 KBi
#17
Correcto
0.006 s 1 KBi
#18
Correcto
0.006 s 1 KBi
#19
Correcto
0.007 s 1 KBi
#20
Correcto
0.007 s 1 KBi
Puntos totales: 100 / 100

Código

#include <iostream>
#include <vector>

using namespace std;

int main() {
  int n, sum, magic=-1;
  cin >> n;

  int square[n][n];

  vector<int> cols(n, 0);
  vector<int> rows(n, 0);
  int diag1=0, diag2=0;

  for(int row=0;row<n;row++){
    for(int col=0;col<n;col++){
      cin >> square[row][col];
      int current = square[row][col];
      cols[col] += current;
      rows[row] += current;
      if(row==col){
        diag1+=current;
      }

      if(col== (n-1-row) ){
        diag2+=current;
      }

    }
  }

  magic = diag1;

  if(magic != diag2){
    cout << "No";
    return 0;
  }

  for(int i=0;i<n;i++){
    if(rows[i]!=magic){
      cout << "No";
      return 0;
    }
    if(cols[i]!=magic){
      cout << "No";
      return 0;
    }
  }
  cout << "Yes";

}