일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 입출력 패턴
- vscode
- k-eta
- string 함수
- 매크로
- getline
- 장고란
- iOS14
- 프레임워크와 라이브러리의 차이
- Django란
- scanf
- c++
- correlation coefficient
- 2557
- 백준
- EOF
- 시간복잡도
- 이분그래프
- 구조체와 클래스의 공통점 및 차이점
- 알고리즘 공부방법
- 자료구조
- 표준 입출력
- 입/출력
- Django Nodejs 차이점
- double ended queue
- UI한글변경
- string 메소드
- 연결요소
- 엑셀
- Django의 편의성
Archives
- Today
- Total
Storage Gonie
챕터3-20. DP | 문제 풀이4 - (3) 백준 No.9461 : 파도반 수열 본문
반응형
파도반 수열 문제
- https://www.acmicpc.net/problem/9461
문제요약
삼각형으로 나선을 만드는데 변의 길이가 1인 정삼각형에서 시작한다.
다음 삼각형은 지금까지 만들어진 나선에서 가장 긴 변에 정삼각형을 추가한다.
파도반 수열 P(N)은 나선에 있는 정삼각형의 변의 길이이다.
P(1) ~ P(12) = 1, 1, 1, 2, 2, 3, 4, 5, 7, 9, 12
P(N)의 값을 출력하는 프로그램을 작성해라.
해결 방법
1. D[i] 정의
생략.
2. 점화식 세우기
방법1. 직감으로 본뒤 점화식이 옳은지 확인
P(12) = 12, P(11) = 9, P(7) = 3 에서 볼 수 있듯이 P(12) = P(11) + P(7) 이다. 또한, 이러한 패턴을 다른곳에서도 보여준다.
따라서, D[i] = D[i-1] + D[i-5] 의 점화식을 세울 수 있다.
방법2. 직감으로 본뒤 점화식이 옳은지 확인
P(12) = 12, P(9) = 5, P(10) = 7 에서 볼 수 있듯이 P(12) = P(10) + P(9) 이다. 또한, 이러한 패턴을 다른곳에서도 보여준다.
따라서, D[i] = D[i-2] + D[i-3] 의 점화식을 세울 수 있다.
<Bottom-up 방식>
* overflow때문에 long long 형으로 해줘야 한다.
(1)시간복잡도
= for 문의 반복 횟수
(2) 구현
-> 'for문을 이용한 반복문'으로 구현
/*방법1*/
#include <iostream>
using namespace std;
long long d[101];
int main()
{
int T;
cin >> T;
while(T--){
int n;
cin >> n;
d[1] = 1;
d[2] = 1;
d[3] = 1;
d[4] = 2;
d[5] = 2;
for (int i = 6; i <= n; i++)
d[i] = d[i - 1] + d[i - 5];
cout << d[n] << "\n";
}
}
/*방법2*/
#include <iostream>
using namespace std;
long long d[101];
int main()
{
int T;
cin >> T;
while(T--){
int n;
cin >> n;
d[1] = 1;
d[2] = 1;
d[3] = 1;
for (int i = 4; i <= n; i++)
d[i] = d[i - 2] + d[i - 3];
cout << d[n] << "\n";
}
}
반응형
'알고리즘 > 알고리즘 기초(코드플러스)' 카테고리의 다른 글
챕터3-22. DP | 문제 풀이4 - (5) 백준 No.2011 : 암호코드 (0) | 2019.05.17 |
---|---|
챕터3-21. DP | 문제 풀이4 - (4) 백준 No.2225 : 합분해 (0) | 2019.05.17 |
챕터3-19. DP | 문제 풀이4 - (2) 백준 No.2133 : 타일 채우기 (0) | 2019.05.17 |
챕터3-18. DP | 문제 풀이4 - (1) 백준 No.1699 : 제곱수의 합 (0) | 2019.05.17 |
챕터3-17. DP | 문제 풀이3 - (6) 백준 No.2579 : 계단 오르기 (0) | 2019.05.16 |
Comments