More actions
({CREATE}) |
No edit summary |
||
| Line 11: | Line 11: | ||
== 박인서 == | == 박인서 == | ||
#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; | |||
} | |||
== 곽정흠 == | == 곽정흠 == | ||
| Line 18: | Line 68: | ||
== 박인서 == | == 박인서 == | ||
* Queen은 자신의 상하좌우에 모두 다른 말이 있으면 잡힌다. | |||
* 따라서 1줄씩 Queen을 놓고 상하좌우를 체크한다. | |||
* 이 것을 이용하는데 전체적으로 Queen 탐색이 왼쪽 위에서 시작되므로 4개 방향만 탐색을 해주면 된다. | |||
== 곽정흠 == | == 곽정흠 == | ||
Revision as of 07:47, 21 September 2016
오늘의 문제
참가자
- 박인서
코드
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개 방향만 탐색을 해주면 된다.