N-Queen 문제 소스코드
IT 위키
C 언어[편집 | 원본 편집]
#include <stdio.h>
#include <stdlib.h>
void queens(int);
int promising(int);
int n;
int col[255]={0,};
FILE *inputFile, *outputFile;
int main() {
char fileName[255];
printf("input num? ");
scanf("%d", &n);
queens(0);
}
void printResult() {
int i;
printf("result : ");
for(i = 1; i<=n; i++) printf("%d ", col[i]);
exit(1);
}
void queens(int i) {
int j;
if(promising(i)) {
if(i == n) printResult();
else
for(j = 1; j <= n; j++) {
col[i+1] = j;
queens(i+1);
}
}
}
int promising(int i) { // 직선, 대각선으로 만나는지 검사
int k = 1, promising = 1;
while(k < i && promising) {
if(col[i] == col[k] || abs(col[i]-col[k]) == abs(i-k))
promising = 0;
k++;
}
return promising;
}