My program needs to check if the input matrix is a magic square.
It is almost done, but I have a problem with fuction. I am not sure why but it return wrong values. I need function to return 1 if square is magic and to return 0 if square isn´t magic. I am getting weird output and segmentation fault.
example of input:
3 - size of square, square:
8 1 6
3 5 7
4 9 2
example of output (function return 1 because square is magic) printed on screen is Square is magic.
Code:
#include<stdio.h>
#include <stdlib.h>
int is_magic(int m[][size], size_t size)
{
int sum = 0;
for(size_t col = 0; col < size; col++)
{
sum += m[col];
}
for(size_t row = 1; row < size; row++)
{
int psum = 0;
for(size_t col = 0; col < size; col++)
{
psum += m[col + row * size];
}
if(psum != sum) return 0;
}
for(size_t col = 0; col < size; col++)
{
int psum = 0;
for(size_t row = 0; row < size; row++)
{
psum += m[col + row * size];
}
if(psum != sum) return 0;
}
return 1;
}
int main()
{
int size,row,column;
scanf("%d",&size);
int *matrix
matrix = (int**)malloc(size * sizeof(int*));
for (row = 0; row < size; row++)
matrix[row] = (int*)malloc(size * sizeof(int));
for (row = 0; row < size; row++)
for (column = 0; column < size; column++)
scanf("%d ", &matrix[row][column]);
if(is_magic(matrix, size))
{
printf("Magic square");
}
else
{
printf("Not magic square");
}
return 0;
}