Submission #557877

#TimeUsernameProblemLanguageResultExecution timeMemory
557877FatihSolakW (RMI18_w)C++17
30 / 100
1099 ms32032 KiB
#include <bits/stdc++.h> #define N 300005 using namespace std; const int mod = 1e9 + 7; long long fact[N]; long long ifact[N]; long long binpow(long long a,long long b){ long long ret = 1; while(b){ if(b & 1) ret = ret*a%mod; a = a*a%mod; b >>= 1; } return ret; } long long C(int n,int r){ return fact[n] * ifact[r]%mod*ifact[n-r]%mod; } long long val[N][5]; void solve(){ int n; cin >> n; map<int,int> cnt; for(int i = 1;i<=n;i++){ int x; cin >> x; cnt[x]++; } vector<int> v; for(auto u:cnt) v.push_back(u.second); if(cnt.size() == 2){ if(v[0] < 2 || v[1] < 3){ cout << 0; return; } cout << C(v[0]-2+1,1) *C(v[1]-3+2,2) %mod; return; } for(int i = 2;i<=n;i++){ val[i][2] = (binpow(2,i-1) - 2 + mod)%mod; } for(int i = 3;i<=n;i++){ val[i][3] = (val[i-1][3] + val[i-1][2])%mod; for(int j = 3;j<=i-1;j++){ val[i][3] = (val[i][3] + C(i-1,j-1) * (1 + val[j-1][2]))%mod; } } for(int i = 4;i<=n;i++){ for(int j = 2;j<=i-1;j++){ val[i][4] = (val[i][4] + C(i-1,j-1) * (val[i-j][2] + val[i-j][3]))%mod; } val[i][4] = val[i][4] *2 %mod; } cout << val[n][4] << endl; } int main(){ ios_base::sync_with_stdio(false); cin.tie(nullptr); #ifdef Local freopen("in.txt","r",stdin); freopen("out.txt","w",stdout); #endif fact[0] = ifact[0]= 1; for(int i = 1;i<N;i++){ fact[i] = fact[i-1] * i %mod; ifact[i] = binpow(fact[i],mod-2); } int t = 1; //cin >> t; while(t--){ solve(); } #ifdef Local cout << endl << fixed << setprecision(2) << 1000.0*clock()/CLOCKS_PER_SEC << " milliseconds."; #endif }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...