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 |
Tags
- 백준js
- 리액트
- 백준골드
- 백준nodejs
- 백준구현문제
- 백준알고리즘
- 백준구현
- css기초
- 몽고DB
- CSS
- 프로그래머스코테
- 알고리즘
- 포이마웹
- HTML
- JS프로그래머스
- 리액트커뮤니티
- js코테
- 프로그래머스JS
- 안드로이드 스튜디오
- 자바스크립트
- 코테
- 리액트댓글기능
- HTML5
- JS
- 프로그래머스
- 익스프레스
- dp알고리즘
- 코딩테스트
- 다이나믹프로그래밍
- 백준
Archives
- Today
- Total
개발새발 로그
[JS] 프로그래머스 : 피보나치 수 본문
피보나치 수
피보나치 수는 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
'알고리즘' 카테고리의 다른 글
[JS] 프로그래머스 : 영어 끝말잇기 (0) | 2023.06.12 |
---|---|
[JS] 프로그래머스 : 짝지어 제거하기 (0) | 2023.06.12 |
[JS] 프로그래머스 : 다음 큰 숫자 (0) | 2023.06.12 |
[JS] 프로그래머스 : 숫자의 표현 (0) | 2023.06.12 |
[JS] 프로그래머스 : 이진 변환 반복하기 (0) | 2023.06.12 |