Trying to make a program in C that solves N sized triangular board with M queens problem. Can't even get it to work. My guess it crashes because I use arrays incorrectly. Could you please explain to me what I am doing wrong here?
#include <stdlib.h>
#include <stdio.h>
int checkPlaceability(int n, int (*board)[n], int row, int col);
int placeQueens(int n, int m, int (*board)[n], int col);
void main()
{
int n;
int board[n][n];
int m;
printf("Enter board size: \n");
scanf("%d", &n);
printf("Enter queen count: \n");
scanf("%d", &m);
if(placeQueens(n, m, board, 0) == 0)
{
printf("Solution doesn't exist");
}
else
{
printf("Solution exists");
}
}
checkPlaceability(int n, int (*board)[n], int row, int col)
{
int i;
int j;
for(i = col; i < i++)
{
if(board[i][col] == 1)
{
return 0;
}
}
for(i = 0; i < n; i++)
{
if(board[row][i] == 1)
{
return 0;
}
}
for(i = abs(row - col)+1, j = 0; i < j && j < n; i++, j++)
{
if(board[i][j] == 1)
{
return 0;
}
}
return 1;
}
int placeQueens(int n, int m, int (*board)[n], int col)
{
int i;
int queenCount = m;
if(col >= n)
{
return 1;
}
for(i = 0; i < m; i++)
{
if(checkPlaceability(n, board, i, col) == 1)
{
board[i][col] = 1;
queenCount--;
if(queenCount == 0)
{
return 1;
}
if(placeQueens(n, queenCount, board, col+1) == 1)
{
return 1;
}
board[i][col] = 0;
}
}
return 0;
}