🌞Algorithm/🔥Baekjoon

[Baekjoon] 9711_피보나치

뿌야._. 2026. 1. 9. 11:57
문제(출처: https://www.acmicpc.net/problem/9711)

< 피보나치 >

 

문제 풀이 

 

피보나치 수열을 dp로 구한다. 이때, BigInteger를 사용한다.

 

my solution (Java)

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.math.BigInteger;
import java.util.StringTokenizer;

public class _9711_ { // 피보나치

	public static void main(String[] args) throws IOException {
		BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		StringTokenizer st;

		int t = Integer.parseInt(bf.readLine());

		int arr[][] = new int[2][t];
		int max = 0;

		for (int i = 0; i < t; i++) {
			st = new StringTokenizer(bf.readLine());
			arr[0][i] = Integer.parseInt(st.nextToken());
			arr[1][i] = Integer.parseInt(st.nextToken());
			max = Math.max(max, arr[0][i]);
		}

		BigInteger dp[] = new BigInteger[max + 1];
		dp[1] = BigInteger.valueOf(1);
		dp[2] = BigInteger.valueOf(1);
		for (int i = 3; i < max + 1; i++) {
			dp[i] = dp[i - 1].add(dp[i - 2]);
		}

		for (int i = 0; i < t; i++) {
			bw.write("Case #" + (i + 1) + ": " + (dp[arr[0][i]].mod(BigInteger.valueOf(arr[1][i]))) + "\n");
		}
		bw.flush();
	}
}
변수)
t : 테스트 케이스 개수
arr : P, Q
dp : 피보나치 

 

테스트 케이스 개수를 입력받는다. 테스트 케이스 수만큼 P와 Q 값을 입력받아 배열 arr에 저장한다. BigInteger를 사용하여 피보나치를 구한 후, 각 값을 Q로 나눠 출력한다.