#include<cstdio> #include<algorithm> #include<vector> using namespace std; #define INF 1000000007 #define CNT 300005 int n; long long tab[CNT]; long long res[CNT]; int main() { scanf("%d", &n); for(int i=0;i<n;i++){ scanf("%lld", tab+i); } if((tab[0]%INF)%2==0) { res[0]=1; } long long akt; long long resi; for(int i=1;i<n;i++){ /*for(int j=0;j<n;j++){ printf("%lld ",res[j]); } printf("\n"); printf("wypelniam dla: %d liczba:%lld\n",i,tab[i]); */ resi=0; akt=0; for(int j=0;j<i;j++){ akt+=tab[i-j]; akt%=INF; //printf("sprawdzam j:%d akt:%lld\n",j,akt); if((akt%INF)%2==0){ //printf("jest parzysty\n"); resi+=res[i-j-1]; resi%=INF; } else { //printf("nie jest parzysty\n"); } } akt+=tab[0]; akt%=INF; if(akt%2==0) resi++; if(resi>=INF) resi-=INF; res[i]=resi; } printf("%lld\n",res[n-1]); 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 | #include<cstdio> #include<algorithm> #include<vector> using namespace std; #define INF 1000000007 #define CNT 300005 int n; long long tab[CNT]; long long res[CNT]; int main() { scanf("%d", &n); for(int i=0;i<n;i++){ scanf("%lld", tab+i); } if((tab[0]%INF)%2==0) { res[0]=1; } long long akt; long long resi; for(int i=1;i<n;i++){ /*for(int j=0;j<n;j++){ printf("%lld ",res[j]); } printf("\n"); printf("wypelniam dla: %d liczba:%lld\n",i,tab[i]); */ resi=0; akt=0; for(int j=0;j<i;j++){ akt+=tab[i-j]; akt%=INF; //printf("sprawdzam j:%d akt:%lld\n",j,akt); if((akt%INF)%2==0){ //printf("jest parzysty\n"); resi+=res[i-j-1]; resi%=INF; } else { //printf("nie jest parzysty\n"); } } akt+=tab[0]; akt%=INF; if(akt%2==0) resi++; if(resi>=INF) resi-=INF; res[i]=resi; } printf("%lld\n",res[n-1]); return 0; } |