#include <stdio.h>
const int P=310,N=1010;
bool jd[N];int n,pr[P],id[N],_c,nu[P];
struct BIG{
int l,v[P];
BIG() : l(1) {v[1] = 0;}
inline int &operator [] (register int x) {return v[x];}
}o;
inline BIG operator * (BIG &u,register int x){
for(register int i=1;i<=u.l;u[i]*=x, i++);
for(register int i=1;i<=u.l;u[i+1]+=u[i]/10,u[i]%=10,(u[u.l+1]?u.l++:1),i++);
return u;
}
inline void MP(){
for(register int i=2;i<=(n<<1);i++){
jd[i] == 0 ? pr[++_c] = i ,id[i] = _c : 1;
for(register int j=1;pr[j]*i<=(n<<1) && j<=_c;j++){
jd[pr[j]*i] = 1, id[pr[j]*i] = j;
if(i%pr[j] == 0)break;
}
}
}
inline void add(register int x,register int d){
for(;x!=1;nu[id[x]]+=d,x/=pr[id[x]]);
}
int main(){
scanf("%d", &n) ,MP();
for(register int i=(n<<1);i>n;add(i,1), i--);
for(register int i=1;i<=n;add(i,-1) ,i++);
add(n+1,-1), o[1]=1;
for(register int i=1;i<=_c;i++)
for(;nu[i];o=(o*pr[i]),nu[i]--);
for(register int i=o.l;i;printf("%d",o[i]),i--);
putchar(‘\n‘);
return 0;
}