Submission #37444

#TimeUsernameProblemLanguageResultExecution timeMemory
37444HardNutBootfall (IZhO17_bootfall)C++14
65 / 100
1000 ms3972 KiB
#include<bits/stdc++.h> using namespace std; const int N = 250005; const int mod = 1e9 + 7; typedef long long ll; int n, a[505], sum; vector<int> vec; int ans[N]; int dp[N]; void add(int v) { for (int i = sum; i >= 0; i--) { dp[i + v] += dp[i]; dp[i + v] %= mod; } sum += v; } void del(int v) { sum -= v; for (int i = 0; i <= sum; i++) { dp[i + v] = (dp[i + v] - dp[i] + mod) % mod; } } int main() { cin >> n; dp[0] = 1; for (int i = 1; i <= n; i++) { cin >> a[i]; add(a[i]); } if (sum % 2 == 1) { cout << 0; return 0; } for (int i = 1; i <= sum; i++) { ans[i] = 1; } if (!dp[sum / 2]) { cout << 0; return 0; } for (int i = 1; i <= n; i++) { del(a[i]); for (int j = 1; j <= N; j++) { if ((sum + j) % 2) { ans[j] = 0; continue; } if (!dp[(sum + j) / 2]) { ans[j] = 0; } } add(a[i]); } int cnt = 0; for (int i = 1; i <= sum; i++) { cnt += ans[i]; } cout << cnt << "\n"; for (int i = 1; i <= sum; i++) if (ans[i]) cout << i << " "; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...