結果
問題 | No.27 板の準備 |
ユーザー | scache |
提出日時 | 2014-11-12 04:14:01 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 162 ms / 5,000 ms |
コード長 | 1,104 bytes |
コンパイル時間 | 3,642 ms |
コンパイル使用メモリ | 77,416 KB |
実行使用メモリ | 41,540 KB |
最終ジャッジ日時 | 2024-12-26 10:26:43 |
合計ジャッジ時間 | 7,228 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 18 |
ソースコード
import java.util.Arrays; import java.util.Scanner; /** * yukicoder no.27 * @author scache * */ public class PreparationBoard { public static void main(String[] args) { PreparationBoard p = new PreparationBoard(); } public PreparationBoard() { Scanner sc = new Scanner(System.in); int[] v =new int[4]; for(int i=0;i<v.length;i++) v[i] = sc.nextInt(); solve(v); } public void solve(int[] v) { Arrays.sort(v); int m = 30; int[] dp = new int[m+1]; int res = 10000000; for(int i=1;i<=m;i++){ for(int j=i+1;j<=m;j++){ for(int k=j+1;k<=m;k++){ Arrays.fill(dp, 10000000); dp[0] = 0; calc(dp, i, m); calc(dp, j, m); calc(dp, k, m); int r = 0; for(int l=0;l<v.length;l++) r += dp[v[l]]; res = Math.min(res, r); } } } System.out.println(res); } private void calc(int[] dp, int t, int m){ for(int i=t;i<=m;i++){ if(i-t<0 || dp[i-t]>=10000000) continue; dp[i] = Math.min(dp[i], dp[Math.max(i-t, 0)] + 1); } } }