#include #define rep(i,n) for(int i = 0; i < (n); i++) using namespace std; typedef long long ll; int main(){ cin.tie(0); ios::sync_with_stdio(0); int N; cin >> N; vector A(N, 0); rep(i,N) { int a; cin >> a; A[a]++; } vector F(N + 1, 1); for(ll i = 2; i <= N; i++) F[i] = F[i - 1] * i; ll ans = F[N]; rep(i,N) { assert(ans % F[A[i]] == 0); ans /= F[A[i]]; } cout << ans << endl; }