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
- AlexNet
- 강화학습
- SIFT
- 자료구조
- 인공지능
- exists
- clustering
- image processing
- edge detection
- dynamic programming
- sklearn
- classification
- opencv
- 백준
- 머신러닝
- 딥러닝
- 그래프 이론
- C++
- MySQL
- Python
- Mask Processing
- dfs
- BFS
- TD
- IN
- machine learning
- Reinforcement Learning
- MinHeap
- DP
- canny edge detection
Archives
- Today
- Total
JINWOOJUNG
[ DP - 17626 ] Four Squares 본문
728x90
반응형
문제
접근법
DP 문제이다 직접 해보자.
1 -> 1 -> 1
2 -> 1 + 1 -> 2
3 -> 1 + 1 + 1 -> 3
4 -> $2^2$ -> 1
5 -> $2^2 + 1$ -> 2 = 1 + DP[5- $2^2$ ]
6 -> $2^2 + 1 + 1$ -> 3 = 1 + DP[6-$2^2$]
약간 규칙이 보일 것이다.
자연수 N의 제곱으로 표현되는 1,4,9 등은 1개가 최소이다. N의 제곱으로 표현되지 않으면, 나와 가장 가까운 자연수 N의 제곱을 뺀 DP[] 값에 1을 더해주면 된다.
하지만 예외사항이 발생한다.
23의 경우 위 논리데로 수행하면 DP[23] = DP[7] + 1, DP[7] = DP[3] + 1 = 4이므로 DP[23]은 5이 된다. 이는 넷 혹은 그 이하의 자연수의 제곱의 합으로 표현할 수 없다.
우리가 간과한 것은 가능한 최소 경우의 수를 찾는 것이다. 23의 경우 1,4,9,16 총 4개의 자연수 N의 제곱이 존재한다. 따라서 이 4가지 모두 고려하였을 때 최소의 경우의 수로 선정해야 한다.
이제 구현해보자.
정답
#include<iostream>
#include<algorithm>
#include <limits.h>
using namespace std;
int32_t ars32_DP[50001];
int main()
{
ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
int32_t s32_Input, s32_I, s32_J, int32_Cnt = 2;
cin >> s32_Input;
ars32_DP[1] = 1;
ars32_DP[2] = 2;
ars32_DP[3] = 3;
for (s32_I = 4; s32_I <= s32_Input; s32_I++)
{
if (s32_I == int32_Cnt * int32_Cnt)
{
ars32_DP[s32_I] = 1;
int32_Cnt += 1;
}
else
{
int32_t s32_Tmp = INT_MAX;
for (s32_J = 1; s32_J * s32_J < s32_I; s32_J++)
{
s32_Tmp = min(s32_Tmp, ars32_DP[s32_I - ((s32_J) * (s32_J))]);
}
ars32_DP[s32_I] = s32_Tmp + 1;
}
}
cout << ars32_DP[s32_Input] << endl;
return 0;
}
728x90
반응형
'백준' 카테고리의 다른 글
[ 정렬 - 24173 ] 알고리즘 수업 - 힙 정렬 1(C++) (2) | 2024.04.03 |
---|---|
[ 트리 - 1991 ] 트리 순회(C++) (0) | 2024.04.03 |
[ DP - 2579 ] 계단 오르기 (0) | 2024.03.31 |
[ DP - 1149 ] RGB거리(C++) (0) | 2024.03.31 |
[ DP - 1003 ] 피보나치 함수 (0) | 2024.03.30 |