結果

問題 No.533 Mysterious Stairs
ユーザー kohaku_kohaku
提出日時 2017-06-23 22:51:27
言語 Java
(openjdk 23)
結果
AC  
実行時間 332 ms / 5,000 ms
コード長 774 bytes
コンパイル時間 2,127 ms
コンパイル使用メモリ 77,312 KB
実行使用メモリ 102,240 KB
最終ジャッジ日時 2024-10-04 07:47:04
合計ジャッジ時間 10,725 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 28
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = sc.nextInt();
        long mod = (long)Math.pow(10,9)+7;
        long [][] num = new long [1000001][4];
        num[1][1] = 1;
        num[2][2] = 1;
        num[3][1] = 1;
        num[3][2] = 1;
        num[3][3] = 1;
        for(int i=4; i<=N; i++){
            num[i][1] = num[i-1][2]+num[i-1][3];
            num[i][2] = num[i-2][1]+num[i-2][3];
            num[i][3] = num[i-3][1]+num[i-3][2];
            for(int j=0; j<3; j++){
                num[i][j]%=mod;
            }
        }
        long ans=0;
        for(int i=1; i<=3; i++){
            ans+=num[N][i];
        }
        System.out.println(ans%mod);
    }
}
0