Description
有一种图形叫做五角形圈。一个五角形圈的中心有1个由n个顶点和n条边组成的圈。在中心的这个n边圈的每一条边同时也是某一个五角形的一条边,一共有n个不同的五角形。这些五角形只在五角形圈的中心的圈上有公共的顶点。如图0所示是一个4-五角形圈。
现在给定一个n五角形圈,你的任务就是求出n五角形圈的不同生成树的数目。还记得什么是图的生成树吗?一个图的生成树是保留原图的所有顶点以及顶点的数目减去一这么多条边,从而生成的一棵树。
注意:在给定的n五角形圈中所有顶点均视为不同的顶点。
Input
输入包含多组测试数据。第一行包含一个正整数T,表示测试数据数目。每组测试数据包含一个整数n( 2<=N<=100),代表你需要求解的五角形圈中心的边数。
Output
对每一组测试数据,输出一行包含一个整数x,表示n五角形圈的生成树数目模2007之后的结果。
Sample Input
1
2
2
Sample Output
40
【解析】
有一个五边形是要删两条边的,一条随便选,一条是确定的,n个五边形选一个,所以有4*n种删法
其他的五边形就删一条边所以有5^(n-1)种
所以勒,总共就是4*n*5^(n-1)
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int mod=2007;
typedef long long LL;
LL power_mod(LL a,LL b,LL c)
{
LL ans=1;a%=c;ans%=c;
while(b>=1)
{
if(b%2==1) ans=(ans*a)%mod;
b/=2;
a*=a;a%=mod;
}
return ans;
}
int main()
{
int t;scanf("%d",&t);
while(t--)
{
int n;
scanf("%d",&n);
LL ans=power_mod(5,n-1,mod);
ans=ans*4*n%mod;
printf("%lld\n",ans);
}
return 0;
}
5n−1