#include <bits/stdc++.h> using namespace std; long long n,suma,w; int tab[5007]; long long m0[25000000]; long long m1[25000000]; int main() { cin>>n; for(int i=0; i<n; i++) { cin>>tab[i]; } sort(tab, tab+n); m0[0]=1; if(tab[0]==1) { suma+=tab[0]; m1[0]=m0[0]; m1[1]=m0[0]; for(int i=2; i<=n; i++) { if(tab[i-1]<=suma+1) { if(i%2==0){ for(int j=0; j<=suma; j++) { m0[j]=m1[j]; } suma+=tab[i-1]; for(int j=2*tab[i-1]-1;j<=suma; j++) { m0[j]=m1[j]+m1[j-tab[i-1]]; } } else { for(int j=0; j<=suma; j++) { m1[j]=m0[j]; } suma+=tab[i-1]; for(int j=2*tab[i-1]-1;j<=suma; j++) { m1[j]=m0[j]+m0[j-tab[i-1]]; } } } else { if(i%2==0){ for(int j=0; j<=suma; j++) { w+=m1[j]; if(w>=1000000007) w%=1000000007; } cout<<w; return 0; } else { for(int j=0; j<=suma; j++) { w+=m0[j]; if(w>=1000000007) w%=1000000007; } cout<<w; return 0; } } } } else { cout<<0; return 0; } for(int j=1; j<=suma; j++) { if(n%2==0){ w+=m0[j]; if(w>=1000000007) w%=1000000007; } else { w+=m1[j]; if(w>=1000000007) w%=1000000007; } } cout<<w<<endl; return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 | #include <bits/stdc++.h> using namespace std; long long n,suma,w; int tab[5007]; long long m0[25000000]; long long m1[25000000]; int main() { cin>>n; for(int i=0; i<n; i++) { cin>>tab[i]; } sort(tab, tab+n); m0[0]=1; if(tab[0]==1) { suma+=tab[0]; m1[0]=m0[0]; m1[1]=m0[0]; for(int i=2; i<=n; i++) { if(tab[i-1]<=suma+1) { if(i%2==0){ for(int j=0; j<=suma; j++) { m0[j]=m1[j]; } suma+=tab[i-1]; for(int j=2*tab[i-1]-1;j<=suma; j++) { m0[j]=m1[j]+m1[j-tab[i-1]]; } } else { for(int j=0; j<=suma; j++) { m1[j]=m0[j]; } suma+=tab[i-1]; for(int j=2*tab[i-1]-1;j<=suma; j++) { m1[j]=m0[j]+m0[j-tab[i-1]]; } } } else { if(i%2==0){ for(int j=0; j<=suma; j++) { w+=m1[j]; if(w>=1000000007) w%=1000000007; } cout<<w; return 0; } else { for(int j=0; j<=suma; j++) { w+=m0[j]; if(w>=1000000007) w%=1000000007; } cout<<w; return 0; } } } } else { cout<<0; return 0; } for(int j=1; j<=suma; j++) { if(n%2==0){ w+=m0[j]; if(w>=1000000007) w%=1000000007; } else { w+=m1[j]; if(w>=1000000007) w%=1000000007; } } cout<<w<<endl; return 0; } |