Problem : https://programmers.co.kr/learn/courses/30/lessons/12941
코딩테스트 연습 - 최솟값 만들기
길이가 같은 배열 A, B 두개가 있습니다. 각 배열은 자연수로 이루어져 있습니다. 배열 A, B에서 각각 한 개의 숫자를 뽑아 두 수를 곱합니다. 이러한 과정을 배열의 길이만큼 반복하며, 두 수를 곱
programmers.co.kr
Approach
간단히 DP를 이용하여 n번째 피보나치 수 % 1234567를 구하는 문제이다.
Code
public class Fibonacci {
public static void main(String[] args) {
int n = 5;
Fibonacci f = new Fibonacci();
System.out.println(f.solution(n));
}
public int solution(int n) {
int[] fibo = new int[n + 1];
fibo[0] = 0;
fibo[1] = 1;
for (int i = 2; i <= n; i++) {
fibo[i] = (fibo[i - 1] + fibo[i - 2]) % 1234567;
}
return fibo[n];
}
}
'Algorithm > Programmers' 카테고리의 다른 글
[java] 프로그래머스 (JadenCase 문자열 만들기) Level 2 (0) | 2021.01.16 |
---|---|
[java] 프로그래머스 (행렬의 곱셈) Level 2 (0) | 2021.01.16 |
[java] 프로그래머스 (최솟값 만들기) Level 2 (0) | 2021.01.14 |
[java] 프로그래머스 (최댓값과 최솟값) Level 2 (0) | 2021.01.14 |
[java] 프로그래머스 (이진 변환 반복하기) Level 2 (0) | 2021.01.14 |