솜은 코튼
[알고리즘] 피보나치 수 본문
피보나치 수
[문제 설명]
피보나치 수는 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은 1이상, 100000이하인 자연수입니다.
[입출력 예]
n | return |
3 | 2 |
5 | 5 |
* 입출력 예 설명
입출력 예
피보나치수는 0번째부터 0, 1, 1, 2, 3, 5, ... 와 같이 이어집니다.
[적용 소스]
1
2
3
4
5
6
7
8
9
10
11
12
13
|
class Solution {
public int solution(int n) {
int x=0, answer = 1, div=1234567;
for(int i=2; i<=n; i++){
int y=answer;
answer=(x%div+answer%div)%div;
x=y;
}
return answer;
}
}
|
cs |
[3] : a[i-2]+a[i-1]=a[i]의 피보나치 수 기준으로 x는 a[i-2], answer은 a[i-1], div는 나눗셈 할 값
[7] : n자리 피보나치 수를 div값으로 나눈 나머지 값 리턴
* 주의점
: 피보나치 수의 계산으로 인해 값이 커지면서 int 자료형 크기에 맞지 않게 되는 입력값이 존재한다.
이를 해결하기 위해 아래와 같은 방법을 사용하여야 한다.
(a + b) % c -> a%c + b%c
* 해당 글은 프로그래머스 페이지에서 제공받은 문제로 작성하였습니다. 출처: https://programmers.co.kr/
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
'알고리즘 > Java' 카테고리의 다른 글
[알고리즘] 1차 캐시 (0) | 2020.07.30 |
---|---|
[알고리즘] 실패율 (0) | 2020.07.17 |
[알고리즘] 시저 암호 (0) | 2020.07.13 |
[알고리즘] 문자열 다루기 기본 (0) | 2020.07.11 |
[알고리즘] 문자열 압축 (0) | 2020.07.10 |