간 간 ..--;;
구 ..^^;;
~cpp //12:50 //1:25 # include <stdio.h> # include <conio.h> # define SIZE 8 char P[SIZE][SIZE]; char Q[SIZE]; int c; int Check(int in) { int re=0; for(int i=c;i>0;i--){ if((in-i)>=0 && P[c-i][in-i] ==1){//.. return 0; } if( (in+i)<SIZE && P[c-i][in+i]==1 ){//.. return 0; } } if (i==0) return 1; return 0; } int EQ() { int re; for(int i=0;i<SIZE;i++){ if(Q[i]==1) continue;// 그 queen .. //..그 걸 .. if(Check(i)>0 ){//I .. Q[i]=1; P[c][i]=1; c++; if(c==SIZE){// .. return 1; } re=EQ(); if (re==1) return 1; c--; Q[i]=0; P[c][i]=0; } } return 0; } void Init() { for (int i=0;i<SIZE;i++){ for(int j=0;j<SIZE;j++) P[i][j]=0; Q[i]=0; } c=0; } void RESULT() { for(int i=0;i<SIZE;i++){ for(int j=0;j<SIZE;j++)printf("%d ",P[i][j]); printf("\n"); } } void main(void) { Init(); EQ(); RESULT(); getch(); return; }
..
EQ() return 1 계 고..
결과 .
그고 결과 거 .
EQ() return 1 계 고..
결과 .
그고 결과 거 .
~cpp //12:50 //1:25 # include <stdio.h> # include <conio.h> # define SIZE 8 char P[SIZE][SIZE]; char Q[SIZE]; int c; void RESULT() { static int count=0; count++; printf("solv %d\n",count); for(int i=0;i<SIZE;i++){ for(int j=0;j<SIZE;j++)printf("%d ",P[i][j]); printf("\n"); } printf("\n"); } int Check(int in) { int re=0; for(int i=c;i>0;i--){ if((in-i)>=0 && P[c-i][in-i] ==1){//.. return 0; } if( (in+i)<SIZE && P[c-i][in+i]==1 ){//.. return 0; } } if (i==0) return 1; return 0; } int EQ() { int re; for(int i=0;i<SIZE;i++){ if(Q[i]==1) continue;// 그 queen .. //..그 걸 .. if(Check(i)>0 ){//I .. Q[i]=1; P[c][i]=1; c++; if(c==SIZE){// .. // return 1; RESULT(); } re=EQ(); // if (re==1) return 1; c--; Q[i]=0; P[c][i]=0; } } return 0; } void Init() { for (int i=0;i<SIZE;i++){ for(int j=0;j<SIZE;j++) P[i][j]=0; Q[i]=0; } c=0; } void main(void) { Init(); EQ(); // RESULT(); getch(); return; }