일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 구조체와 클래스의 공통점 및 차이점
- 장고란
- 입출력 패턴
- 프레임워크와 라이브러리의 차이
- 시간복잡도
- 매크로
- 입/출력
- Django의 편의성
- double ended queue
- 표준 입출력
- Django란
- 알고리즘 공부방법
- 백준
- scanf
- EOF
- getline
- k-eta
- 이분그래프
- 엑셀
- 자료구조
- string 메소드
- vscode
- UI한글변경
- correlation coefficient
- iOS14
- c++
- string 함수
- Django Nodejs 차이점
- 연결요소
- 2557
Archives
- Today
- Total
Storage Gonie
챕터3-18. DP | 문제 풀이4 - (1) 백준 No.1699 : 제곱수의 합 본문
반응형
제곱수의 합 문제
- 백준 No.9095 : 1, 2, 3 더하기 문제와 비슷함
- https://www.acmicpc.net/problem/1699
문제요약
어떤 자연수 N이 주어지면 이를 N보다 작은 제곱수의 합으로 나타내는 데,
이때의 항의 최소개수를 구해라.
해결 방법
1. D[i] 정의
D[N] = "자연수 N을 제곱수의 합으로 나타내는데 이때의 항의 최소개수"
2. 점화식 세우기
정수 N이 주어지면 앞에 어떤 조합들이 오고 맨 뒤에 i^2이 온다고 해보자.
O + O + O + ... + i^2 = N 이 된다.
여기서 i^2를 제외시킨 앞의 나머지 항들에 대해서만 생각해보면 D[N] = min(D[N - i^2] + 1) 가 된다.
i^2 이 1^2, 2^2, 3^2, ,.....이 될 수 있기 때문에. i의 범위를 생각해야하는데 이는 문제의 조건에 의해서 i^2 <= N 이 된다.
<Bottom-up 방식>
(1)시간복잡도
= for 문의 반복 횟수
i의 범위를 계산해 보면은 문제의 조건에 의해서 i^2 <= N 이 된다. 이는 다시 i <= 루트N이 되며
N개의 D를 구해야하고 i의 범위는 루트n이므로 이 문제의 시간복잡도는 O(N루트N) 이 된다.
이를 코드상에서 구현하게 되면 바깥 for문은 N번의 반복, 안쪽 for문은 루트N의 반복이 있게 됨.
(루트N의 반복은 제곱시켜서 아래와 같이 나타낼 수 있음)
(2) 구현
-> 'for문을 이용한 반복문'으로 구현
#include<iostream>
using namespace std;
int d[100001];
int main()
{
int n;
cin >> n;
for (int i = 1; i <= n; i++){
d[i] = i; // 최대값을 초기값으로 넣어줌. 1을 i번 하면 최대값이기 때문.
for(int j = 1; j*j <= i; j++){
if(d[i] > d[i -(j*j)] + 1)
d[i] = d[i -(j*j)] + 1;
}
}
cout << d[n] << "\n";
}
반응형
'알고리즘 > 알고리즘 기초(코드플러스)' 카테고리의 다른 글
챕터3-20. DP | 문제 풀이4 - (3) 백준 No.9461 : 파도반 수열 (0) | 2019.05.17 |
---|---|
챕터3-19. DP | 문제 풀이4 - (2) 백준 No.2133 : 타일 채우기 (0) | 2019.05.17 |
챕터3-17. DP | 문제 풀이3 - (6) 백준 No.2579 : 계단 오르기 (0) | 2019.05.16 |
챕터3-16. DP | 문제 풀이3 - (5) 백준 No.1912 : 연속합 (0) | 2019.05.15 |
챕터3-15. DP | 문제 풀이3 - (4) 백준 No.11054 : 가장 긴 바이토닉 부분 수열 (0) | 2019.05.15 |
Comments