일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 회고록
- 조합론
- dfs
- 백트래킹
- NEXT
- 자바스크립트
- c++
- 가끔은_말로
- DP
- 세그먼트 트리
- object detection
- pytorch
- 크루스칼
- 이분 탐색
- 우선 순위 큐
- 미래는_현재와_과거로
- 2023
- 알고리즘
- back propagation
- lazy propagation
- 분할 정복
- Overfitting
- 너비 우선 탐색
- dropout
- tensorflow
- 플로이드 와샬
- BFS
- 가끔은 말로
- 문자열
- 다익스트라
Archives
- Today
- Total
Doby's Lab
[알고리즘] 백준 9465번: 스티커 (C++), 논리와 직관 그 어디쯤 사이에 본문
https://www.acmicpc.net/problem/9465
이번 문제는 TC를 보고 나서 점화식을 어떻게 짜야할지 혼란을 가져다주는 문제였다.
하지만, TC를 간단하게 생각해보면 쉽게 풀 수 있었다.
솔루션에 도달하는 과정
5
50 10 100 20 40
30 50 70 10 60
다음 TC가 문제를 다시 생각해보게 했었다. 그 전의 코드는 이렇다.
#include <iostream>
#include <cmath>
using namespace std;
int T;
int cache[2][100001] = { 0, };
int map[2][100001] = { 0, };
int main() {
cin >> T;
for (int t = 0; t < T; t++) {
int n;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> map[0][i];
}
for (int i = 1; i <= n; i++) {
cin >> map[1][i];
}
for (int i = 1; i <= n; i++) {
cache[0][i] = cache[1][i - 1] + map[0][i];
cache[1][i] = cache[0][i - 1] + map[1][i];
}
cout << max(cache[0][n], cache[1][n]) << '\n';
}
return 0;
}
무조건 대각선 방향의 스티커를 더해주는 것이 정답이겠거니 했지만 올린 TC 같은 경우엔 한 칸 더 뒤에 있는 대각선을 택하게 된다.
솔루션에 도달하는 과정 (2)
value와 value2 중에 더 큰 값을 선택하면 된다.
그렇다면 여기서 이런 말이 나올 수 있다. '3칸 뒤의 값도 더 큰 값을 가지고 있을 수 있는데 왜 안 따지는가?'
그에 대한 답은 3칸 뒤에 값을 따질 필요 없이 value를 거쳐 대각선 2개를 더 거치면 value3에 도달할 수 있고, 값 2개를 더 더했으므로 더 큰 값을 초래하기 때문이라는 이유가 답이 된다.
그래서 점화식에서는 두 칸 전의 값까지만 따져주면서 점화식을 도출해내면 된다.
[AC 코드]
#include <iostream>
#include <cmath>
using namespace std;
int T;
int cache[2][100001] = { 0, };
int map[2][100001] = { 0, };
int main() {
cin >> T;
for (int t = 0; t < T; t++) {
int n;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> map[0][i];
}
for (int i = 1; i <= n; i++) {
cin >> map[1][i];
}
for (int i = 1; i <= n; i++) {
cache[0][i] = max(cache[1][i - 1], cache[1][i - 2]) + map[0][i];
cache[1][i] = max(cache[0][i - 1], cache[0][i - 2]) + map[1][i];
}
cout << max(cache[0][n], cache[1][n]) << '\n';
}
return 0;
}
728x90
'PS > BOJ' 카테고리의 다른 글
[알고리즘] 백준 14562번: 태권왕 (C++), 범위 오류 (0) | 2021.11.19 |
---|---|
[알고리즘] 백준 2407번: 조합 (C++), Combination, Permutation (0) | 2021.11.18 |
[알고리즘] 백준 1107번: 리모컨 (C++), 모든 경우의 수 (0) | 2021.11.17 |
[알고리즘] 백준 11725번: 트리의 부모 찾기 (C++), 2차원 동적 배열 (vector) (0) | 2021.11.17 |
[알고리즘] 백준 11561번: 징검다리 (C++), 등차수열의 합, 이젠 수학까지 해야 하니 (0) | 2021.11.15 |