#pragma GCC optimize("Ofast") #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; typedef long long int ll; typedef unsigned long long ull; mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); ll myRand(ll B) { return (ull)rng() % B; } inline double time() { return static_cast(chrono::duration_cast(chrono::steady_clock::now().time_since_epoch()).count()) * 1e-9; } int main(){ cin.tie(nullptr); ios::sync_with_stdio(false); int n; cin >> n; vector cnt(n+1); vector f(n+1); f[0] = 1; for(int i=1;i<=n;i++){ int x; cin >> x; cnt[x]++; f[i] = f[i-1] * (ll)i; } ll res = f[n]; for(int i:cnt){ res /= f[i]; } cout << res << endl; }