250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 백준#BOJ#14501#퇴사#브루트포스
- 백준#BOJ#12865#평범한배낭
- 백준#BOJ#8012#한동이는영업사원
- 백준#boj#12755
- 백준#BOJ#1939#중량제한
- 백준#BOJ#2615#오목
- 백준#boj#16932#모양만들기
Archives
- Today
- Total
순간을 성실히, 화려함보단 꾸준함을
[ boj : 17492 ] 바둑알 점프 본문
https://www.acmicpc.net/problem/17492
해설 : 바둑알이 인접한 바둑알을 넘어서면 넘겨진 바둑알은 사라집니다. 이 행위를 반복해서 바둑알을 1개를 만들 수 있냐 없냐를 구하는 문제입니다.
https://www.acmicpc.net/problem/9207
사실 이 문제랑 그렇게 별 차이가 없죠. 굳이 찾으라면 최소인지 아니면 단 한개만 남길 수 있을 것이지 구하는 차이??
백트래킹을 사용해서 구해줍시다. 어차피 n의 범위는 10밖에 안되니깐 이중포문을 돌려서 바둑알이 있다면 8방향으로 넘길 수 있는지 체크를 한 후에 넘길수 있으면 지워줄 애들을 지워주고 넘깁니다.
다시 돌아왔을때는 원상태로 만들어줘야겠죠???
#include<bits/stdc++.h>
using namespace std;
int n;
int board[10][10];
int dx[] = { -1,-1,0,1,1,1,0,-1 }, dy[] = { 0,1,1,1,0,-1,-1,-1 };
string ans = "Impossible";
void dfs();
int main()
{
cin >> n;
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++)
cin >> board[i][j];
dfs();
cout << ans;
}
void dfs()
{
int cnt = 0;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
if (board[i][j]==2) {
cnt++;
for (int d = 0; d < 8; d++) {
int tx = i + dx[d];
int ty = j + dy[d];
if (tx < 0 || tx >= n || ty < 0 || ty >= n)continue;
if (board[tx][ty] == 2 && board[tx+dx[d]][ty+dy[d]]==0) {
board[i][j] = 0;
board[tx][ty] = 0;
board[tx + dx[d]][ty + dy[d]] = 2;
dfs();
board[tx + dx[d]][ty + dy[d]] = 0;
board[tx][ty] = 2;
board[i][j] = 2;
}
}
}
if (cnt == 1) {
ans = "Possible";
}
return;
}
'알고리즘,SQL > 백준,BOJ' 카테고리의 다른 글
[ boj : 2661 ] 좋은 수열 (0) | 2021.10.19 |
---|---|
[ boj : 2602 ] 돌다리 건너기 (0) | 2021.10.11 |
[ boj : 17370 ] 육각형 우리 속의 개미 (0) | 2021.10.09 |
[ boj : 2533 ] 사회망 서비스(SNS) (0) | 2021.10.06 |
[ boj : 1262 ] 알파벳 다이아몬드 (0) | 2021.10.02 |