1137 计算系数
数论or递推2011年NOIP全国联赛提高组
时间限制: 1 s
空间限制: 128000 KB
题目等级 : 黄金 Gold
查看运行结果
题解:杨辉三角+快速幂+同余与模算术
思想版:
#includeusing namespace std;#define N 1001#define mod 10007int a,b,k,n,m;long long f[N][N];long long quick_pow(long long x,long long n){ if(n==0) return 1; else{ while((n&1)==0){ n>>=1; x=(x*x)%mod; } } long long result=x; n>>=1; while(n!=0){ x=(x*x)%mod; if((n&1)!=0){ result=(result*x)%mod; } n>>=1; } return result;}void init(){ for(int i=0;i<=k;i++) f[i][0]=f[i][i]=1; for(int i=2;i<=k;i++){ for(int j=1;j
递推版:
#includeusing namespace std;#define N 1100#define mod 10007int f[N][N];int a,b,k,n,m;int main(){ scanf("%d%d%d%d%d",&a,&b,&k,&n,&m); a%=mod; b%=mod; f[1][0]=a; f[1][1]=b; for(int i=2;i<=k;i++){ for(int j=0;j<=i&&j<=m;j++){ f[i][j]=f[i-1][j]*a%mod; if(j) f[i][j]=(f[i][j]+f[i-1][j-1]*b)%mod; } } printf("%d\n",f[k][m]); return 0;}