Park DJ
dj0998
Park DJ
전체 방문자
오늘
어제
  • 분류 전체보기 (363)
    • 백준 (363)

공지사항

인기 글

태그

  • 백준 15655
  • 백준
  • 백준 2343
  • 백준 7662
  • 백준 24039
  • 백준 16194
  • 백준 14582
  • 자바
  • 백준 3049
  • 백준 6550
  • 백준 3135
  • Java
  • 백준 2225
  • 백준 7567
  • 백준 2467
  • 백준 1064
  • 백준 15961
  • 백준 1011
  • 백준 2591
  • 백준 1531
  • 백준 10709
  • 백준 1747
  • 백준 4659
  • 백준 12605
  • 백준 1914
  • 백준 1495
  • 백준 8892
  • 백준 15312
  • 백준 16926
  • 백준 12871
hELLO · Designed By 정상우.
Park DJ

dj0998

백준 15988 1, 2, 3 더하기 3(Java)
백준

백준 15988 1, 2, 3 더하기 3(Java)

2023. 2. 10. 16:53

https://www.acmicpc.net/problem/15988

 

15988번: 1, 2, 3 더하기 3

각 테스트 케이스마다, n을 1, 2, 3의 합으로 나타내는 방법의 수를 1,000,000,009로 나눈 나머지를 출력한다.

www.acmicpc.net


 

해석 및 팁

 


 

이 문제는 백준 9095 1, 2, 3 더하기와 거의 같은 문제입니다. arr [1] = 1, arr [2] = 1+1, 2, arr [3]= 1+1+1, 1+2, 2+1, 3 일 때 arr [4]부터는 arr [n] = arr [n-1] + arr [n-2] + arr [n-3] 이므로 다이나믹프로그래밍을 사용하주면 되고  1,000,000,009로 나눈 나머지를 출력해야하므로 모듈러연산을 이용해 주면 됩니다.

 


 

Java 코드

 


import java.util.Scanner;

public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    StringBuilder sb = new StringBuilder();

    int t = sc.nextInt();
   
    for(int i = 0; i < t; i++) {
      int n = sc.nextInt();
      long[] arr = new long[1000001];
      arr[1] = 1;
      arr[2] = 2;
      arr[3] = 4;
      for(int j = 4; j <= n; j++) arr[j] = (arr[j - 1] + arr[j - 2] + arr[j - 3]) % 1000000009;
      sb.append(arr[n]+"\n");
    }

    System.out.println(sb);
  }
}

'백준' 카테고리의 다른 글

백준 5567 결혼식(Java)  (0) 2023.02.10
백준 2075 N번째 큰 수(Java)  (0) 2023.02.10
백준 15664 N과 M (10)(Java)  (0) 2023.02.10
백준 18111 마인크래프트(Java)  (0) 2023.02.10
백준 2477 참외밭(Java)  (0) 2023.02.10
    '백준' 카테고리의 다른 글
    • 백준 5567 결혼식(Java)
    • 백준 2075 N번째 큰 수(Java)
    • 백준 15664 N과 M (10)(Java)
    • 백준 18111 마인크래프트(Java)
    Park DJ
    Park DJ

    티스토리툴바