#include #define int long long const int mod=1e9+7; using namespace std; int ycl[100005],ny[100005]; int ksm(int a,int n){ int ans=1,k=mod; int a2=a,n2=n; while(n>0){ if(n%2==1) ans=((ans%k)*(a%k))%k; n=n/2; a=(a%k)*(a%k); } return ans%k; } void sol(){ int n,ans=0; cin>>n; ycl[1]=ycl[0]=1; ny[1]=1; ny[0]=1; for(int i=2;i<=n;i++) { ycl[i]=ycl[i-1]*i%mod; ny[i]=ksm(ycl[i],mod-2)%mod; }for(int i=0;i<=n;i++){ ans+=(((ycl[n]*ny[i]%mod)*ny[n-i])%mod*ksm(n-i,i))%mod; ans%=mod; }cout<