首页 > 其他 > 详细

[题解]luogu_P4430猴子打架

时间:2019-05-09 21:05:27      阅读:106      评论:0      收藏:0      [点我收藏+]

来源:题解

比较不错的博客:http://www.cnblogs.com/dirge/p/5503289.html

最后生成一颗无根树,有n^(n-2)种情况,打架的顺序有(n-1)!种

#include<bits/stdc++.h>
using namespace std;
const int mod=9999991;
int n;
long long ans=1;
int main(){
    scanf("%d",&n);
    for(int i=1;i<=n-2;i++)ans=(ans*n)%mod;
    for(int i=1;i<=n-1;i++)ans=(ans*i)%mod;
    printf("%lld\n",ans);
}

最后生成一颗有根树,每个点做根有n^(n-2)种情况,共n^(n-1)种

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=1e9+9;
ll n;
inline ll qpow(ll a,ll b){
    ll base=a,ans=1;
    while(b){
        if(b&1)ans=(ans*base)%mod;
        base=(base*base)%mod;
        b>>=1;
    }
    return ans%mod;
}
int main(){int T;
    scanf("%d",&T);
    for(int pp=1;pp<=T;pp++){
        scanf("%d",&n);
        printf("%lld\n",qpow(n,n-1));
    }
}

 

[题解]luogu_P4430猴子打架

原文:https://www.cnblogs.com/superminivan/p/10840838.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!