Submission #1369871


Source Code Expand

#include <stdio.h>  
#include <algorithm>  
#include <assert.h>
#include <bitset>
#include <cmath>  
#include <complex>  
#include <deque>  
#include <functional>  
#include <iostream>  
#include <limits.h>  
#include <map>  
#include <math.h>  
#include <queue>  
#include <set>  
#include <stdlib.h>  
#include <string.h>  
#include <string>  
#include <time.h>  
#include <unordered_map>  
#include <unordered_set>  
#include <vector>  

#pragma warning(disable:4996)  
#pragma comment(linker, "/STACK:336777216")  
using namespace std;

#define mp make_pair  
#define Fi first  
#define Se second  
#define pb(x) push_back(x)  
#define szz(x) ((int)(x).size())  
#define rep(i, n) for(int i=0;i<n;i++)  
#define all(x) (x).begin(), (x).end()  
#define ldb ldouble  

typedef tuple<int, int, int> t3;
typedef long long ll;
typedef unsigned long long ull;
typedef double db;
typedef long double ldb;
typedef pair <int, int> pii;
typedef pair <ll, ll> pll;
typedef pair <ll, int> pli;
typedef pair <db, db> pdd;

int IT_MAX = 1 << 15;
const ll MOD = 1000000007;
const int INF = 0x3f3f3f3f;
const ll LL_INF = 0x3f3f3f3f3f3f3f3f;
const db PI = acos(-1);
const db ERR = 1e-10;

bool dp1[5050][5050];
bool dp2[5050][5050];
int in[5050];
int sum[5050];
int main() {
	int N, K, i, j, k;
	scanf("%d %d", &N, &K);
	for (i = 1; i <= N; i++) scanf("%d", &in[i]);

	dp1[0][0] = true;
	for (i = 1; i <= N; i++) {
		for (j = 0; j <= K; j++) {
			dp1[i][j] = dp1[i - 1][j];
			if (j >= in[i] && dp1[i - 1][j - in[i]]) dp1[i][j] = true;
		}
	}
	dp2[N + 1][0] = true;
	for (i = N; i >= 1; i--) {
		for (j = 0; j <= K; j++) {
			dp2[i][j] = dp2[i + 1][j];
			if (j >= in[i] && dp2[i + 1][j - in[i]]) dp2[i][j] = true;
		}
	}

	int ans = 0;
	for (i = 1; i <= N; i++) {
		sum[0] = 1;
		for (j = 1; j <= K; j++) sum[j] = sum[j - 1] + (int)dp2[i + 1][j];
		
		for (j = 0; j < K; j++) {
			if (!dp1[i-1][j]) continue;
			int st = max(0, K - in[i] - j), en = K - 1 - j;
			if (sum[en] != ((st == 0) ? 0 : sum[st - 1])) break;
		}
		if (j >= K) ans++;
	}
	return !printf("%d\n", ans);
}

Submission Info

Submission Time
Task D - No Need
User dotorya
Language C++14 (GCC 5.4.1)
Score 600
Code Size 2152 Byte
Status AC
Exec Time 115 ms
Memory 49792 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:59:24: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d %d", &N, &K);
                        ^
./Main.cpp:60:46: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  for (i = 1; i <= N; i++) scanf("%d", &in[i]);
                                              ^

Judge Result

Set Name Sample Subtask All
Score / Max Score 0 / 0 300 / 300 300 / 300
Status
AC × 3
AC × 26
AC × 51
Set Name Test Cases
Sample 0_000.txt, 0_001.txt, 0_002.txt
Subtask 0_000.txt, 0_001.txt, 0_002.txt, 1_003.txt, 1_004.txt, 1_005.txt, 1_006.txt, 1_007.txt, 1_008.txt, 1_009.txt, 1_010.txt, 1_011.txt, 1_012.txt, 1_013.txt, 1_014.txt, 1_015.txt, 1_016.txt, 1_017.txt, 1_018.txt, 1_019.txt, 1_020.txt, 1_021.txt, 1_022.txt, 1_023.txt, 1_024.txt, 1_025.txt
All 0_000.txt, 0_001.txt, 0_002.txt, 1_003.txt, 1_004.txt, 1_005.txt, 1_006.txt, 1_007.txt, 1_008.txt, 1_009.txt, 1_010.txt, 1_011.txt, 1_012.txt, 1_013.txt, 1_014.txt, 1_015.txt, 1_016.txt, 1_017.txt, 1_018.txt, 1_019.txt, 1_020.txt, 1_021.txt, 1_022.txt, 1_023.txt, 1_024.txt, 1_025.txt, 2_026.txt, 2_027.txt, 2_028.txt, 2_029.txt, 2_030.txt, 2_031.txt, 2_032.txt, 2_033.txt, 2_034.txt, 2_035.txt, 2_036.txt, 2_037.txt, 2_038.txt, 2_039.txt, 2_040.txt, 2_041.txt, 2_042.txt, 2_043.txt, 2_044.txt, 2_045.txt, 2_046.txt, 2_047.txt, 2_048.txt, 2_049.txt, 2_050.txt
Case Name Status Exec Time Memory
0_000.txt AC 2 ms 2304 KB
0_001.txt AC 2 ms 2304 KB
0_002.txt AC 2 ms 2304 KB
1_003.txt AC 2 ms 2304 KB
1_004.txt AC 2 ms 2304 KB
1_005.txt AC 2 ms 2304 KB
1_006.txt AC 2 ms 2304 KB
1_007.txt AC 2 ms 2304 KB
1_008.txt AC 4 ms 6144 KB
1_009.txt AC 4 ms 6144 KB
1_010.txt AC 3 ms 6144 KB
1_011.txt AC 3 ms 5888 KB
1_012.txt AC 3 ms 6144 KB
1_013.txt AC 3 ms 5888 KB
1_014.txt AC 3 ms 6016 KB
1_015.txt AC 3 ms 6144 KB
1_016.txt AC 2 ms 2304 KB
1_017.txt AC 2 ms 2304 KB
1_018.txt AC 2 ms 2304 KB
1_019.txt AC 3 ms 6016 KB
1_020.txt AC 3 ms 6016 KB
1_021.txt AC 3 ms 6016 KB
1_022.txt AC 2 ms 3072 KB
1_023.txt AC 2 ms 2816 KB
1_024.txt AC 3 ms 6016 KB
1_025.txt AC 3 ms 6016 KB
2_026.txt AC 2 ms 2304 KB
2_027.txt AC 2 ms 2432 KB
2_028.txt AC 2 ms 2432 KB
2_029.txt AC 107 ms 49792 KB
2_030.txt AC 115 ms 49792 KB
2_031.txt AC 62 ms 49792 KB
2_032.txt AC 12 ms 49408 KB
2_033.txt AC 62 ms 49792 KB
2_034.txt AC 12 ms 49408 KB
2_035.txt AC 12 ms 49408 KB
2_036.txt AC 79 ms 49792 KB
2_037.txt AC 2 ms 2304 KB
2_038.txt AC 2 ms 2432 KB
2_039.txt AC 2 ms 2432 KB
2_040.txt AC 53 ms 49792 KB
2_041.txt AC 47 ms 49792 KB
2_042.txt AC 66 ms 49792 KB
2_043.txt AC 40 ms 33024 KB
2_044.txt AC 46 ms 45312 KB
2_045.txt AC 28 ms 41216 KB
2_046.txt AC 51 ms 49792 KB
2_047.txt AC 70 ms 49792 KB
2_048.txt AC 87 ms 49792 KB
2_049.txt AC 81 ms 49792 KB
2_050.txt AC 78 ms 49792 KB