結果
問題 | No.220 世界のなんとか2 |
ユーザー |
|
提出日時 | 2015-06-01 00:52:57 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 136 ms / 1,000 ms |
コード長 | 672 bytes |
コンパイル時間 | 3,563 ms |
コンパイル使用メモリ | 75,008 KB |
実行使用メモリ | 54,280 KB |
最終ジャッジ日時 | 2024-07-06 13:05:34 |
合計ジャッジ時間 | 6,937 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 19 |
ソースコード
import java.util.Scanner; public class Main_yukicoder220 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int p = sc.nextInt(); long[] dp = new long[p + 1]; long[][] dp2 = new long[3][p + 1]; long base = 1; for (int i = 1; i <= p; i++) { for (int j = 0; j < 10; j++) { if (j == 3) { dp[i] += base; } else { dp[i] += dp[i - 1]; if (base == 1) { dp2[j % 3][i]++; } else { for (int k = 0; k < 3; k++) { dp2[(int)((base * j + k) % 3)][i] += dp2[k][i - 1]; } } } } base *= 10; } System.out.println(dp[p] + dp2[0][p] - 1); sc.close(); } }