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
- 알고리즘
- Go언어
- scala
- 리눅스
- programmers
- DP
- 파이썬
- zookeeper
- 스칼라
- OOM
- Python
- Java
- 프로그래머스
- 자바
- redis
- HBase
- 문제풀이
- 동적프로그래밍
- 코드워
- boj
- Linux
- leetcode
- 주키퍼
- go
- dynamic programming
- docker
- codewars
- gradle
- 튜토리얼
- golang
Archives
- Today
- Total
파이문
1003. 피보나치 함수 본문
728x90
1003. 피보나치 함수
(https://www.acmicpc.net/problem/1003)
숫자를 입력받아, (피보나치 계산으로) 1과 0을 얼마나 호출하는지를 출력하는 문제이다. 케이스 범위에 따라, 이전 계산 값을 그대로 사용할 수 있게 보완하면 더 좋을듯
public void problem1003(int n) {
if (n == 0) {
System.out.println("1 0");
} else if (n == 1) {
System.out.println("0 1");
} else if (n == 2) {
System.out.println("1 1");
} else {
int[][] dp = new int[n + 1][2];
dp[1][0] = 0;
dp[1][1] = 1;
dp[2][0] = 1;
dp[2][1] = 1;
dp[3][0] = 1;
dp[3][1] = 2;
for (int i = 4; i <= n; ++i) {
dp[i][0] = dp[i - 1][0] + dp[i - 2][0];
dp[i][1] = dp[i - 1][1] + dp[i - 2][1];
}
System.out.println(dp[n][0] + " " + dp[n][1]);
}
}
public static void main(String[] args) {
Main sol = new Main();
Scanner sc = new Scanner(System.in);
int cases = sc.nextInt();
while (cases != 0) {
int n = sc.nextInt();
sol.problem1003(n);
cases -= 1;
}
}
}
'문제 풀이 > BOJ' 카테고리의 다른 글
11053. 가장 긴 증가하는 부분 수열 (0) | 2017.11.12 |
---|---|
2579. 계단 오르기 (0) | 2017.11.12 |
1149. RGB 거리 (0) | 2017.04.04 |
1463. 1로 만들기 (0) | 2017.04.03 |
Maximum Random Walks (0) | 2016.04.17 |
Comments