제출 #93356

#제출 시각아이디문제언어결과실행 시간메모리
93356toloraiaBootfall (IZhO17_bootfall)C++14
0 / 100
2 ms380 KiB
#include <bits/stdc++.h> #define ll long long int using namespace std; const int N = 505, M = 260010; const int B = 1e9 + 7; int n; int a[N]; int S; bool f; int DP[M]; int dp[M]; int ans[M], ANS[M]; int V[M], np; int i, j; int main() { cin>>n; for (i = 1; i <= n; i++){ cin>>a[i]; S += a[i]; } sort (a + 1, a + n + 1); bool ok = 0; for (i = 2; i <= n; i++) if ((a[i] - a[i - 1]) % 2 == 1) ok = 1; if (S % 2 == 1) ok = 1; if (ok){ cout<<0<<endl; return 0; } DP[0] = 1; for (i = 1; i <= n; i++){ for (j = S; j >= a[i]; j--){ DP[j] += DP[j - a[i]]; if (DP[j] >= B) DP[j] -= B; } } if (DP[S / 2] == 0){ cout<<0<<endl; return 0; } for (int I = 1; I <= n; ++I){ for (int i = 0; i <= S; ++i){ dp[i] = DP[i]; ans[abs (S - 2 * i - a[I])] = 0; } for (int i = 0; i <= S; ++i){ f = 1; if (i >= a[I]){ f = 0; dp[i] -= dp[i - a[I]]; if (dp[i] < 0) dp[i] += B; if (dp[i]) f = 1; } if (f && ans[abs (S - a[I] - 2 * i)] == 0){ ans[abs (S - a[I] - 2 * i)] = 1; ANS[abs (S - a[I] - 2 * i)]++; } } } np = 0; for (i = 0; i <= S; i++) if (ANS[i] == n) V[np++] = i; cout<<np<<endl; for (i = 0; i < np; i++) cout<<V[i]<<" "; cout<<endl; return 0; }
#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...