반응형
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
- softeer
- 기술면접
- 이분탐색
- OFFSET
- @P0
- 처우산정
- msSQL
- 퇴사통보
- 물채우기
- 소프티어
- 백준
- 성적평가
- 파라메트릭
- 매개변수탐색
- incr
- 경력
- Docker
- Kafka
- 오퍼레터
- dfs
- boj #19237 #어른 상어
- BOJ
- 6987
- 13908
- upper_bound
- 연결요소
- 백트래킹
- compose
- 처우협의
- BFS
Archives
- Today
- Total
기술 블로그
14391번 종이 조각 본문
728x90
반응형
use 2차원 배열이 true일 때는 가로, false일 때는 세로로 생각하여 계산한다.
#include <bits/stdc++.h>
using namespace std;
#define MAX 5
int R, C, answer = INT32_MIN;
int p[MAX][MAX];
bool use[MAX][MAX], tmp[MAX][MAX];
int calc(vector<int> &v)
{
string str = "";
for (auto i : v) str += to_string(i);
return stoi(str);
}
vector<int> make_set(int r, int c, int L, bool pivot)
{
vector<int> v;
// 가로 == true
if (pivot) for (int j = c; j < c + L; j++) v.push_back(p[r][j]);
// 세로 == false
else for (int i = r; i < r + L; i++) v.push_back(p[i][c]);
return v;
}
int len(int r, int c, bool pivot)
{
int ret = 0;
// 가로 == true
if (pivot) {
for (int j = c; j < C; j++) {
if (use[r][j] && !tmp[r][j]) {
tmp[r][j] = true;
++ret;
}
else break;
}
}
// 세로 == false
else {
for (int i = r; i < R; i++) {
if (!use[i][c] && !tmp[i][c]) {
tmp[i][c] = true;
++ret;
}
else break;
}
}
return ret;
}
void bf(int y, int x)
{
if (y == R) {
memset(tmp, false, sizeof(tmp));
int sum = 0;
for (int i = 0; i < R; i++) {
for (int j = 0; j < C; j++) {
if (p[i][j] && !tmp[i][j]) {
int L = len(i, j, use[i][j]);
vector<int> v = make_set(i, j, L, use[i][j]);
sum += calc(v);
}
}
}
answer = max(answer, sum);
return;
}
if (x == C) {
++y;
x = 0;
}
use[y][x] = true;
bf(y, x + 1);
use[y][x] = false;
bf(y, x + 1);
}
int main(void)
{
cin.tie(0);
scanf("%d %d", &R, &C);
for (int i = 0; i < R; i++) for (int j = 0; j < C; j++) scanf("%1d", &p[i][j]);
bf(0, 0);
printf("%d\n", answer);
return 0;
}
728x90
반응형
'알고리즘 문제 > BOJ' 카테고리의 다른 글
6987번 월드컵 (0) | 2021.04.09 |
---|---|
13908번 비밀번호 (0) | 2021.04.06 |
17485번 진우의 달 여행 (Large) (3) | 2021.03.20 |
1562번 계단수 (0) | 2021.03.08 |
19237번 어른상어 (0) | 2021.02.13 |