#include <bits/stdc++.h>
using namespace std;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL)
#define mofile(s) freopen(s,"r",stdin)
#define outfile(s) freopen(s,"w",stdout)
#define ll long long
#define ii pair<ll,ll>
#define iii pair<ll,ii>
#define fi first
#define se second
#define tf bool
#define ST stack
#define DQ deque
#define Q queue
#define S string
#define Ma map
#define UM unormideremid_map
#define SE set
#define str(x) to_string(x)
#define all(a) (a).begin(),(a).end()
#define FOR(i,l,r,mid) for(int i=l;i<=r;i+=mid)
#define FOD(i,l,r,mid) for(int i=r;i>=l;i-=mid)
#define xuong cout<<"\n"
#define midebug(x) cout<<(x)<<" "
#define ppcnt(x) __builtin_popcountll(x)
#define parity(x) __builtin_parityll(x)
#define leamid0(x) __builtin_clzll(x)
#define LOG2 __lg(x)
#define tr0(x) __builtin_ctzll(x)
#define fiset(x) __builtin_ffsll(x)
#define MASK(k) (1LL<<(k))
#define BIT(x,k) ((x)>>(k)&1)
#define pb push_back
#define tron(x) setprecision(x)
#define het return 0
#define base_ 1000000000
template<typename... T>
void in(T&... args) { ((cin >> args), ...); }
template<class X, class Y>
bool maximize(X &x, const Y &y){return (x < y) ? x = y, 1 : 0;}
template<class X, class Y>
bool minimize(X &x, const Y &y){return (x > y) ? x = y, 1 : 0;}
const ll maxn=1e6+5;
const ll tle=2e8;
const ll INF=1e9+9;
const int base=31;
//const ll MOD=1e9+7;
string bcc="abcmidefghijklmnopqrstuvwxyz";
int midx[]={-1,0,1,0};
int midy[]={0,1,0,-1};
bool sang[10000005];
ll pref[1005][1005],mt[1005][1005];
void sieve(){
for(int i=1;i<=10000000;++i) sang[i]=1;
sang[0]=sang[1]=0;
for(int i=2;i*i<=10000000;++i){
if(sang[i]){
for(int j=i*i;j<=10000000;j+=i) sang[j]=0;
}
}
}
void lis(){
vector<int>t;
vector<int>a;
int n; cin>>n;
for(int i=1;i<=n;++i){
int ai; cin>>ai;
a.pb(ai);
}
for(int x:a){
auto it=lower_bound(all(t),x);
if(it==t.end()) t.pb(x);
else *it=x;
}
}
void pfs2mid(){
int n,m,k; cin>>n>>k; m=n;
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j) cin>>mt[i][j];
}
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j) pref[i][j]=mt[i][j]+pref[i-1][j]+pref[i][j-1]-pref[i-1][j-1];
}
}
ll qu2mid(int x1,int y1,int x2,int y2){
return pref[x2][y2]-pref[x1-1][y2]-pref[x2][y1-1]+pref[x1-1][y1-1];
}
const int N=1e6,MOD=1e9+7;
int64_t F[N+1],F1[N+1],a[N+1];
int n;
map<int,int>mp;
int64_t binpow(int64_t a,int64_t b) {
int64_t ans=1;
while(b){
if(b&1) ans=ans*a%MOD;
a=a*a%MOD;
b/=2;
}
return ans;
}
void init(){
F[0]=1;
for(int i=1;i<=N;++i) F[i]=F[i - 1]*i%MOD;
F1[N]=binpow(F[N],MOD-2);
for(int i=N;i>0;--i) F1[i-1]=F1[i]*i%MOD;
}
int main() {
fast;
init();
cin>>n;
for(int i=1;i<=n;++i){
cin>>a[i];
++mp[a[i]];
}
int64_t ans=F[n];
for(auto [val,cnt]:mp) ans=(ans%MOD*F1[cnt]%MOD)%MOD;
cout<<ans<<"\n";
het;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgZmFzdCBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsgY2luLnRpZShOVUxMKTsgY291dC50aWUoTlVMTCkKI2RlZmluZSBtb2ZpbGUocykgZnJlb3BlbihzLCJyIixzdGRpbikKI2RlZmluZSBvdXRmaWxlKHMpIGZyZW9wZW4ocywidyIsc3Rkb3V0KQojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIGlpIHBhaXI8bGwsbGw+CiNkZWZpbmUgaWlpIHBhaXI8bGwsaWk+CiNkZWZpbmUgZmkgZmlyc3QKI2RlZmluZSBzZSBzZWNvbmQKI2RlZmluZSB0ZiBib29sCiNkZWZpbmUgU1Qgc3RhY2sKI2RlZmluZSBEUSBkZXF1ZQojZGVmaW5lIFEgcXVldWUKI2RlZmluZSBTIHN0cmluZwojZGVmaW5lIE1hIG1hcAojZGVmaW5lIFVNIHVub3JtaWRlcmVtaWRfbWFwCiNkZWZpbmUgU0Ugc2V0CiNkZWZpbmUgc3RyKHgpIHRvX3N0cmluZyh4KQojZGVmaW5lIGFsbChhKSAoYSkuYmVnaW4oKSwoYSkuZW5kKCkKI2RlZmluZSBGT1IoaSxsLHIsbWlkKSBmb3IoaW50IGk9bDtpPD1yO2krPW1pZCkKI2RlZmluZSBGT0QoaSxsLHIsbWlkKSBmb3IoaW50IGk9cjtpPj1sO2ktPW1pZCkKI2RlZmluZSB4dW9uZyBjb3V0PDwiXG4iCiNkZWZpbmUgbWlkZWJ1Zyh4KSBjb3V0PDwoeCk8PCIgIgojZGVmaW5lIHBwY250KHgpIF9fYnVpbHRpbl9wb3Bjb3VudGxsKHgpCiNkZWZpbmUgcGFyaXR5KHgpIF9fYnVpbHRpbl9wYXJpdHlsbCh4KQojZGVmaW5lIGxlYW1pZDAoeCkgX19idWlsdGluX2NsemxsKHgpCiNkZWZpbmUgTE9HMiBfX2xnKHgpCiNkZWZpbmUgdHIwKHgpIF9fYnVpbHRpbl9jdHpsbCh4KQojZGVmaW5lIGZpc2V0KHgpIF9fYnVpbHRpbl9mZnNsbCh4KQojZGVmaW5lIE1BU0soaykgKDFMTDw8KGspKQojZGVmaW5lIEJJVCh4LGspICgoeCk+PihrKSYxKQojZGVmaW5lIHBiIHB1c2hfYmFjawojZGVmaW5lIHRyb24oeCkgc2V0cHJlY2lzaW9uKHgpCiNkZWZpbmUgaGV0IHJldHVybiAwCiNkZWZpbmUgYmFzZV8gMTAwMDAwMDAwMAp0ZW1wbGF0ZTx0eXBlbmFtZS4uLiBUPgp2b2lkIGluKFQmLi4uIGFyZ3MpIHsgKChjaW4gPj4gYXJncyksIC4uLik7IH0KdGVtcGxhdGU8Y2xhc3MgWCwgY2xhc3MgWT4KICAgIGJvb2wgbWF4aW1pemUoWCAmeCwgY29uc3QgWSAmeSl7cmV0dXJuICh4IDwgeSkgPyB4ID0geSwgMSA6IDA7fQp0ZW1wbGF0ZTxjbGFzcyBYLCBjbGFzcyBZPgogICAgYm9vbCBtaW5pbWl6ZShYICZ4LCBjb25zdCBZICZ5KXtyZXR1cm4gKHggPiB5KSA/IHggPSB5LCAxIDogMDt9CmNvbnN0IGxsIG1heG49MWU2KzU7CmNvbnN0IGxsIHRsZT0yZTg7CmNvbnN0IGxsIElORj0xZTkrOTsKY29uc3QgaW50IGJhc2U9MzE7Ci8vY29uc3QgbGwgTU9EPTFlOSs3OwpzdHJpbmcgYmNjPSJhYmNtaWRlZmdoaWprbG1ub3BxcnN0dXZ3eHl6IjsKaW50IG1pZHhbXT17LTEsMCwxLDB9OwppbnQgbWlkeVtdPXswLDEsMCwtMX07CmJvb2wgc2FuZ1sxMDAwMDAwNV07CmxsIHByZWZbMTAwNV1bMTAwNV0sbXRbMTAwNV1bMTAwNV07CnZvaWQgc2lldmUoKXsKICAgIGZvcihpbnQgaT0xO2k8PTEwMDAwMDAwOysraSkgc2FuZ1tpXT0xOwogICAgc2FuZ1swXT1zYW5nWzFdPTA7CiAgICBmb3IoaW50IGk9MjtpKmk8PTEwMDAwMDAwOysraSl7CiAgICAgICAgaWYoc2FuZ1tpXSl7CiAgICAgICAgICAgIGZvcihpbnQgaj1pKmk7ajw9MTAwMDAwMDA7ais9aSkgc2FuZ1tqXT0wOwogICAgICAgIH0KICAgIH0KfQp2b2lkIGxpcygpewogICAgdmVjdG9yPGludD50OwogICAgdmVjdG9yPGludD5hOwogICAgaW50IG47IGNpbj4+bjsKICAgIGZvcihpbnQgaT0xO2k8PW47KytpKXsKICAgICAgICBpbnQgYWk7IGNpbj4+YWk7CiAgICAgICAgYS5wYihhaSk7CiAgICB9CiAgICBmb3IoaW50IHg6YSl7CiAgICAgICAgYXV0byBpdD1sb3dlcl9ib3VuZChhbGwodCkseCk7CiAgICAgICAgaWYoaXQ9PXQuZW5kKCkpIHQucGIoeCk7CiAgICAgICAgZWxzZSAqaXQ9eDsKICAgIH0KfQp2b2lkIHBmczJtaWQoKXsKICAgIGludCBuLG0sazsgY2luPj5uPj5rOyBtPW47CiAgICBmb3IoaW50IGk9MTtpPD1uOysraSl7CiAgICAgICAgZm9yKGludCBqPTE7ajw9bTsrK2opIGNpbj4+bXRbaV1bal07CiAgICB9CiAgICBmb3IoaW50IGk9MTtpPD1uOysraSl7CiAgICAgICAgZm9yKGludCBqPTE7ajw9bTsrK2opIHByZWZbaV1bal09bXRbaV1bal0rcHJlZltpLTFdW2pdK3ByZWZbaV1bai0xXS1wcmVmW2ktMV1bai0xXTsKICAgIH0KfQpsbCBxdTJtaWQoaW50IHgxLGludCB5MSxpbnQgeDIsaW50IHkyKXsKICAgIHJldHVybiBwcmVmW3gyXVt5Ml0tcHJlZlt4MS0xXVt5Ml0tcHJlZlt4Ml1beTEtMV0rcHJlZlt4MS0xXVt5MS0xXTsKfQpjb25zdCBpbnQgTj0xZTYsTU9EPTFlOSs3OwppbnQ2NF90IEZbTisxXSxGMVtOKzFdLGFbTisxXTsKaW50IG47Cm1hcDxpbnQsaW50Pm1wOwppbnQ2NF90IGJpbnBvdyhpbnQ2NF90IGEsaW50NjRfdCBiKSB7CiAgICBpbnQ2NF90IGFucz0xOwogICAgd2hpbGUoYil7CiAgICAgICAgaWYoYiYxKSBhbnM9YW5zKmElTU9EOwogICAgICAgIGE9YSphJU1PRDsKICAgICAgICBiLz0yOwogICAgfQogICAgcmV0dXJuIGFuczsKfQp2b2lkIGluaXQoKXsKICAgIEZbMF09MTsKICAgIGZvcihpbnQgaT0xO2k8PU47KytpKSBGW2ldPUZbaSAtIDFdKmklTU9EOwogICAgRjFbTl09YmlucG93KEZbTl0sTU9ELTIpOwogICAgZm9yKGludCBpPU47aT4wOy0taSkgRjFbaS0xXT1GMVtpXSppJU1PRDsKfQppbnQgbWFpbigpIHsKICAgIGZhc3Q7CiAgICBpbml0KCk7CiAgICBjaW4+Pm47CiAgICBmb3IoaW50IGk9MTtpPD1uOysraSl7CiAgICAgICAgY2luPj5hW2ldOwogICAgICAgICsrbXBbYVtpXV07CiAgICB9CiAgICBpbnQ2NF90IGFucz1GW25dOwogICAgZm9yKGF1dG8gW3ZhbCxjbnRdOm1wKSBhbnM9KGFucyVNT0QqRjFbY250XSVNT0QpJU1PRDsKICAgIGNvdXQ8PGFuczw8IlxuIjsKICAgIGhldDsKfQ==