Toggle menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

1R/2016 09 21

From ZeroWiki
Revision as of 07:47, 21 September 2016 by 165.194.27.163 (talk)

오늘의 문제

참가자

  • 박인서

코드

15이원준

박인서

#include <iostream>
#include <vector>
  
bool a[16][16]={false,};
int cnt=0,n;
  
bool check(int row,int col)
{
        for(int i=0;i<col;i++)
                 if(a[row][i]) return false;
        for(int i=0;i<n;i++)
                 if(a[i][col]) return false;
        for(int i=1;;i++)
        {
                 if(row-i<0 || col-i<0) break;
                 if(a[row-i][col-i]) return false;
        }
        for(int i=1;;i++)
        {
                 if(row-i<0 || col+i>=n) break;
                 if(a[row-i][col+i]) return false;
        }
        return true;
}
  
void queen(int row)
{
        if(row==n)
        {
                 cnt++;
                 return;
        }
        for(int i=0;i<n;i++)
        {
                 if(check(row,i))
                 {
                         a[row][i]=true;
                         queen(row+1);
                         a[row][i]=false;
                 }
        }
}
  
int main()
{
        std::cin>>n;
        queen(0);
        std::cout<<cnt;
        return 0;
}

곽정흠

아이디어

15이원준

박인서

  • Queen은 자신의 상하좌우에 모두 다른 말이 있으면 잡힌다.
  • 따라서 1줄씩 Queen을 놓고 상하좌우를 체크한다.
  • 이 것을 이용하는데 전체적으로 Queen 탐색이 왼쪽 위에서 시작되므로 4개 방향만 탐색을 해주면 된다.

곽정흠