알고리즘
[JS] 프로그래머스 : 피보나치 수
이즈흐
2023. 6. 12. 18:25
피보나치 수
피보나치 수는 F(0) = 0, F(1) = 1일 때, 1 이상의 n에 대하여 F(n) = F(n-1) + F(n-2) 가 적용되는 수 입니다.
예를들어
- F(2) = F(0) + F(1) = 0 + 1 = 1
- F(3) = F(1) + F(2) = 1 + 1 = 2
- F(4) = F(2) + F(3) = 1 + 2 = 3
- F(5) = F(3) + F(4) = 2 + 3 = 5
와 같이 이어집니다.
2 이상의 n이 입력되었을 때, n번째 피보나치 수를 1234567으로 나눈 나머지를 리턴하는 함수, solution을 완성해 주세요.
제한 사항- n은 2 이상 100,000 이하인 자연수입니다.
3 | 2 |
5 | 5 |
피보나치수는 0번째부터 0, 1, 1, 2, 3, 5, ... 와 같이 이어집니다.
문제가 잘 안풀린다면😢힌트가 필요한가요? [코딩테스트 연습 힌트 모음집]으로 오세요! → 클릭
어려웠던 이유
- 피보나치 수에 대한 이해 F(5)는 3+5다. (F(5)는 피보나치의 5번째)
- int형은 2,147,483,647 까지 가능하다. 만약 +1이 되면 -2,147,483,647 되버린다.
- 그래서 문제에 1234567로 나눈 나머지만 저장하는 것은 int의 범위에서 가능하게된다.
- 이유눈 1234567로 나눈 나머지의 수는 1234567보다 무조건 작으므로 저장이 가능함
한줄 요약: 문제에서 1234567로 나눈 나머지를 정답으로 내놓으라는 것은 문제를 꼰 것이 아니라 int 자료형의 범위 내에 항상 값이 있을 수 있도록 한 배려이며, 자료형의 크기에 제한이 있는 언어를 쓸 경우
(A+B) % C = ( (A%C) + (B%C) ) % C 라는 성질을 이용해서 매번 계산 결과에 1234567으로 나눈 나머지를 대신 넣는 것으로 int 범위 내에 할상 값이 존재함을 보장할 수 있다.
첫 번째풀이
function solution(n) {
var answer = 0;
let f1 = 0, f2 = 1;
for(let i = 2; i <= n; i++){
answer = (f1 + f2) % 1234567;
f1 = f2;
f2 = answer;
}
return answer;
}
두 번째 풀이
function solution(n) {
var answer = 0;
let arr=Array.from({length:n+1},()=>0);
arr[0]=0;
arr[1]=1;
for(var i=2;i<=n;i++){
arr[i]=(arr[i-2]+arr[i-1])%1234567
}
return arr[n];
}
728x90
반응형
LIST