일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- #알고리즘 #백준 #1525 #백준1525 #algorithm #baekjoon #baekjoon1525 #C++
- #알고리즘 #백준 #2573 #백준2573 #algorithm #baekjoon #baekjoon2573 #C++
- #알고리즘 #백준 #1987 #백준1987 #algorithm #baekjoon #baekjoon1987 #Java
- 스레드 #동시성 #thread #process #
- #알고리즘 #백준 #1260 #백준1260 #algorithm #baekjoon #baekjoon1260 #Java
- #알고리즘 #백준 #17472 #백준17472 #algorithm #baekjoon #baekjoon17472 #C++
- #알고리즘 #백준 #1793 #백준1793 #algorithm #baekjoon #baekjoon1793 #C++
- #알고리즘 #백준 #3190 #백준3190 #algorithm #baekjoon #baekjoon3190 #C++
- 책리뷰
- CleanCode
- #알고리즘 #백준 #4386 #백준4386 #algorithm #baekjoon #baekjoon4386 #C++
- 클린코드
- #알고리즘 #백준 #15684 #백준15684 #algorithm #baekjoon #baekjoon15684 #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #블록이동하기 #programmers #C++
- #알고리즘 #백준 #17136 #백준17136 #algorithm #baekjoon #baekjoon17136 #C++
- #알고리즘 #백준 #17406 #백준17406 #algorithm #baekjoon #baekjoon17406 #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #외벽점검 #programmers #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #문자열압축 #programmers #C++
- 개발서
- #알고리즘 #백준 #12094 #백준12094 #algorithm #baekjoon #baekjoon12094 #C++
- #알고리즘 #백준 #15683 #백준15683 #algorithm #baekjoon #baekjoon15683 #C++
- 개발자취미
- #알고리즘 #백준 #14888 #백준14888 #algorithm #baekjoon #baekjoon14888 #C++
- #알고리즘 #백준 #17140 #백준17140 #algorithm #baekjoon #baekjoon17140 #C++
- #알고리즘 #백준 #2616 #백준2616 #algorithm #baekjoon #baekjoon2616 #Java
- #알고리즘 #백준 #2352 #백준2352 #algorithm #baekjoon #baekjoon2352 #C++
- #알고리즘 #백준 #17837 #백준17837 #algorithm #baekjoon #baekjoon17837 #C++
- #알고리즘 #백준 #2580 #백준2580 #algorithm #baekjoon #baekjoon2580 #Java
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #괄호변환 #programmers #C++
- #알고리즘 #백준 #5214 #백준5214 #algorithm #baekjoon #baekjoon5214 #C++
Archives
- Today
- Total
개발자 일기장.
백준 17136. 색종이 붙이기 본문
색종이 붙이기
Problem?
문제.
Solution
브루트 포스
dfs를 통한 탐색
색종이 크기안에 빈칸(0)이 있는 경우나 색종이를 잘 붙인 경우는 효율적으로 다음 dfs를 설정한다.
가정 dfs() : 갈 수 있는 경로 탐색
board : 맵 confetti : 남은 색종이 파악 answer : 최소 경우의 답 보관 |
Code
#include <iostream>
#include <algorithm>
using namespace std;
#define MAX 10
#define INF 999999999
int board[MAX][MAX]; // map
int confetti[6] = { 0, 5, 5, 5, 5, 5 }; // confetti count(count per paper)
int answer = INF, cnt = 0; // answer
void dfs(int y, int x){
// if line is end
if (x == MAX) {
dfs(y + 1, 0);
return;
}
// end state
if (y == MAX) {
answer = min(answer, cnt);
return;
}
// if board is empty, check the next position
if (board[y][x] == 0) {
dfs(y, x + 1);
return;
}
// check all possibility (loop : len 5 -> 1)
for (int l = 5; l >= 1; l--) {
if (confetti[l] == 0 || y + l > MAX || x + l > MAX)
continue;
bool flag = false;
for (int i = y; i < y + l; i++){
for (int j = x; j < x + l; j++){
if (board[i][j] == 0) {
flag = true;
break;
}
}
if (flag == true)
break;
}
if (flag == true)
continue;
confetti[l]--;
cnt++;
for (int i = y; i < y + l; i++)
for (int j = x; j < x + l; j++)
board[i][j] = 0;
// efficient way
dfs(y, x + l);
for (int i = y; i < y + l; i++)
for (int j = x; j < x + l; j++)
board[i][j] = 1;
cnt--;
confetti[l]++;
}
}
int main() {
// input
for (int i = 0; i < MAX; i++)
for (int j = 0; j < MAX; j++)
scanf("%d", &board[i][j]);
// solution
dfs(0, 0);
if (answer == INF)
answer = -1;
// output
cout << answer << "\n";
return 0;
}
'취업 > Algorithm.' 카테고리의 다른 글
[2020 카카오 공채] 블록 이동하기 (0) | 2020.03.22 |
---|---|
[2020 카카오 공채] 문자열 압축 (0) | 2020.03.22 |
백준 1525. 퍼즐 (0) | 2020.03.22 |
백준 4386. 별자리 만들기 (0) | 2020.03.16 |
백준 1647. 도시 분할 계획 (0) | 2020.03.16 |