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
- 모두를 위한 딥러닝
- computer vision
- 알고리즘
- 내용추가
- reinforcement learning
- 백준
- object detection
- 논문
- coding test
- 프로그래머스
- Python
Archives
- Today
- Total
NISSO
[백준 1904번] DP로 피보나치 구현 본문
DP 문제를 이제 2~3개 정도 풀어본 것 같은데 드디어 감이 좀 잡히려고 한다.
아직 쉬운 것만 풀어봐서 그럴진 모르겠지만 감이라도 잡힌 것에 감사하고 있다. 풀다보면 늘 거라고 생각한다.
1 1 1
2 2 00 11
3 3 001 100 111
4 5 0000 0011 1001 1100 1111
5 8 00001 00100 10000 00111 10011 11001 11100 11111
6 13 000000 000011 001001 001100 100001 100100 110000 001111 100111 110011 111001 111100 111111
7 21 0000001 0000100 0010000 1000000 0000111 0010011 0011001 0011100 1000011 1001001 1001100 1100100 1110000 1100001 0011111 1001111 1100111 1110011 1111001 1111100 1111111
대충 이런 식으로 7까지 일단 무식하게 풀어봤다.
역시 답 자체가 피보나치였다. 처음엔 이 계산도 잘못해서 분명 패턴이 있는데 뭐지? 싶었다. 그냥 한두개 빼먹은 거였다.
n = int(input())
d = [0]*1000001
d[1], d[2] = 1,2
for i in range(3,n+1):
d[i] = d[i-1]+d[i-2]
print(d[n]%15746)
첫 시도는 메모리 초과였다. 사실 이것도 구글링으로 푼 거라 d의 길이를 최대값 1,000,000 + 1로 놨다.
이 코드로 메모리 초과가 뜨지 않으려면 계산 자체를 15746로 나눠줘야 한다. input에 큰 값이 들어가면 메모리가 초과하기 때문이다.
n = int(input())
d = [0,1,2]
for i in range(3,n+1):
d.append((d[i-1]+d[i-2])%15746)
print(d[n])
마지막으로 제출한 코드.
위 코드에서 d와 d에 입력하는 방식만 달라졌기 때문에 메모리나 시간 차이는 거의 없었다.
오히려 메모리는 이 방법이 더 많이 든다.
나름 동적계획법1 중에서도 단계 3이길래 덜 긴장했는데 좀 더 긴장할 필요가 있겠다.
DP문제가 나오면 자신 있게 풀도록 연습해야겠다.
'Coding Test' 카테고리의 다른 글
[백준 1932] DP 동적계획법3 (0) | 2021.07.01 |
---|---|
[백준 1149] DP 동적계획법2 (0) | 2021.06.29 |
[백준 1003] 피보나치 구현 (0) | 2021.06.28 |
[백준 9663] 백트래킹 대표 문제 N-Queens (0) | 2021.06.27 |
[백준 15652] 백트래킹2와 itertools (0) | 2021.06.27 |
Comments