ソースコード 拡げる

Copy
```/**
* Created on 2016/08/31.
*/

import java.util.*;

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

int N = sc.nextInt();
long A = sc.nextInt();

long[] nums = new long[N];
long maxInput = -1;
for(int i=0; i<N; i++){
nums[i] = sc.nextLong();
maxInput = Math.max(nums[i], maxInput);
}

long ans = solve(N, A, nums, (int)maxInput);

System.out.println(ans);
}

private static long solve(int N, long A, long[] nums, int X) {

long[][][] dp = new long[N+1][N+1][N*X + 1];

//        for(int i=0; i<N+1; i++){
//            for(int j=0; j<N+1; j++){
//                for(int k=0; k<N*X+1; k++){
//                    System.out.println(dp[i][j][k]);
//                }
//            }
//        }

dp[0][0][0] = 1;

for(int i=1; i<N+1; i++){
for(int j=0; j<N+1; j++){
for(int k=0; k<N*X+1; k++){
// 現状
int prevJ = j-1;
int prevK = k-(int)nums[i-1];

if(prevJ < 0 || prevK < 0){
dp[i][j][k] = dp[i-1][j][k];
}else{
dp[i][j][k] = dp[i-1][prevJ][prevK] + dp[i-1][j][k];
}
}
}
}

long ret = 0;
for(int t=0; t<=N; t++){
ret += dp[N][t][t*(int)A];
}

return ret-1;
}

// Algorithms
private static ArrayList<Integer> getPrimeNumbers(int upperLimit) {
ArrayList<Integer> ret = new ArrayList<Integer>();

for (int i = 5; i <= upperLimit; i += 2) {
boolean isPrime = true;
// 素数で平方根まで試し割りしてみる
for (int j = 2; j * j <= i; j++) {
if (i % j == 0) {
isPrime = false;
break;
}
}

if (isPrime) {
}
}
return ret;
}

// View Method
//* List
public static <T> void viewList(List<T> list) {
for (T item : list) {
System.out.print(item + "\t");
}
System.out.println("");
}

//* Map
public static <K, V> void viewMap(Map<K, V> map) {
Set<K> keys = map.keySet();
for (K key : keys) {
System.out.print("(" + key + ", " + map.get(key) + ")\t");
}
System.out.println("");
}

//* Matrix
public static void viewIntMatrix(int[][] matrix) {
for (int i = 0; i < matrix.length; i++) {
for (int j = 0; j < matrix[i].length; j++) {
System.out.print(matrix[i][j] + "\t");
}
System.out.println("");
}
}
}
```

#### 提出情報

提出日時 2016-08-31 09:00:24+0900 C - 高橋君とカード neoki Java8 (OpenJDK 1.8.0) 0 3033 Byte RE 418 ms 77768 KB

#### ジャッジ結果

 AC × 4
 AC × 10 RE × 2
 AC × 21 RE × 3
セット名 テストケース
Sample example_01.txt, example_02.txt, example_03.txt, example_04.txt
ケース名 結果 実行時間 メモリ
example_01.txt AC 202 ms 9420 KB
example_02.txt AC 201 ms 9428 KB
example_03.txt AC 198 ms 9552 KB
example_04.txt AC 214 ms 10440 KB
subtask1_01.txt AC 218 ms 11344 KB
subtask1_02.txt AC 222 ms 11476 KB
subtask1_03.txt AC 221 ms 11472 KB
subtask1_04.txt RE 202 ms 9548 KB
subtask1_05.txt AC 225 ms 11340 KB
subtask1_06.txt AC 193 ms 9428 KB
subtask1_07.txt RE 197 ms 9428 KB
subtask1_08.txt AC 222 ms 11404 KB
subtask1_09.txt AC 218 ms 11152 KB
subtask2_01.txt AC 410 ms 77644 KB
subtask2_02.txt AC 418 ms 77768 KB
subtask2_03.txt AC 370 ms 60748 KB
subtask2_04.txt AC 402 ms 77620 KB
subtask2_05.txt AC 414 ms 77644 KB
subtask2_06.txt RE 226 ms 11012 KB
subtask2_07.txt AC 414 ms 77644 KB
subtask2_08.txt AC 265 ms 33228 KB
subtask2_09.txt AC 286 ms 33228 KB
subtask2_10.txt AC 307 ms 41296 KB
subtask2_11.txt AC 318 ms 42944 KB