#include #include #define rep(i,n) for (int i = 0; i < int(n); ++i) #define repp(i,n,m) for (int i = m; i < int(n); ++i) using namespace std; using namespace atcoder; templateistream &operator>>(istream &is,vector &v){for(auto &e:v)is>>e;return is;} templateostream &operator<<(ostream &os,const vector &v){if(v.size()==0){os<istream &operator>>(istream &is,vector> &v){for(auto &e:v)is>>e;return is;} templateostream &operator<<(ostream &os,const vector> &v){if(v.size()==0){os<void mout(T a){cout<> n; vector ar(n); cin >> ar; auto get = [&](int x, int y){ if (x * y == 0) return 0; if (x == y) return 2; return 1; }; vector> dp(n+1,vector(3,0)); rep(i,n) { int y = 0; if (ar[i] > 50) y = 1; else if (ar[i] < 50) y = 2; dp[i+1][y] += 1; rep(j,3){ dp[i+1][get(j,y)] += dp[i][j]; dp[i+1][j] += dp[i][j]; } } //mout(dp[n][0]); mout(dp[n][1]); //mout(dp[n][2]); }