-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathChrisMagicSquare.java
More file actions
83 lines (71 loc) · 2.36 KB
/
ChrisMagicSquare.java
File metadata and controls
83 lines (71 loc) · 2.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
* Created by MalhotR1 on 01/03/2018.
*/
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class ChrisMagicSquare {
public static void main(String[] args) throws IOException {
try (BufferedReader br = new BufferedReader(new InputStreamReader(System.in))) {
int N = Integer.parseInt(br.readLine().trim());
int[][] matrix = new int[N][N];
int sum = -1;
int z_i = -1;
int z_j = -1;
boolean zero = false;
for (int i = 0; i < N; i++) {
String[] in = br.readLine().trim().split(" ");
int temp = 0;
for (int j = 0; j < N; j++) {
matrix[i][j] = Integer.parseInt(in[j]);
if (matrix[i][j] == 0) {
zero = true;
z_i = i;
z_j = j;
}
temp += matrix[i][j];
}
if (sum == -1 && !zero) sum = temp;
if (sum != -1 && !zero && sum != temp) {
System.out.println(-1);
return;
}
if (sum != -1 && zero) matrix[z_i][z_j] = sum - temp;
zero = false;
}
if (N == 1) {
System.out.println(1);
return;
}
int c = 0;
for (int i = 0; i < N; i++) {
c += matrix[z_i][i];
}
if (matrix[z_i][z_j] == 0)
matrix[z_i][z_j] = sum - c;
if (matrix[z_i][z_j] == 0){
System.out.println(-1);
return;
}
int diag = 0;
int diag2 = 0;
for (int i = 0; i < N; i++) {
int temp = 0;
diag2 += matrix[i][N-1-i];
for (int j = 0; j < N; j++) {
temp += matrix[j][i];
if (i == j) diag += matrix[i][j];
}
if (temp != sum) {
System.out.println(-1);
return;
}
}
if (diag != sum || diag2 != sum) {
System.out.println(-1);
return;
}
System.out.println(matrix[z_i][z_j]);
}
}
}