P1313 计算系数

it2022-05-05  136

P1313 计算系数

题目链接:https://www.luogu.org/problemnew/show/P1313

题目描述

给定一个多项式(ax + by)^k,请求出多项式展开后x^n *y^m项的系数。

输入输出格式

输入格式:  

共一行,包含5个整数,分别为a ,b ,k ,n ,m每两个整数之间用一个空格隔开。

输出格式:

共1 行,包含一个整数,表示所求的系数,这个系数可能很大,输出对10007取模后的结果。

输入输出样例

输入样例#1: 

1 1 3 1 2

输出样例#1: 

3

说明

【数据范围】

对于30% 的数据,有0 ≤k ≤10

对于50%的数据,有a = 1,b = 1

对于100%的数据,有0≤k ≤1,000,0≤n, m≤kn+m=k ,0 ≤a,b ≤1,000,000

noip2011提高组day2第1题

思路:二项式定理展开,用快速幂解决a^n *b^m,然后用杨辉三角的原理去计算组合数

代码:

#include<bits/stdc++.h> using namespace std; #define ll long long #define mod 10007 #define maxn 1000005 #define INF 0x3f3f3f3f #define N 3005 ll C[N][N]; void get_C(int n)//初始化杨辉三角 {     C[0][0] = 1;     for (int i = 1; i <= n; i++)     {          C[i][0] = 1;          for (int j = 1; j <= i; j++)              C[i][j] = (C[i - 1][j] % mod + C[i - 1][j - 1] % mod) % mod;          //C[i][j] = (C[i-1][j]+C[i-1][j-1])%MOD;     } } ll quickpow(ll a, ll b, ll n)//快速幂 {     if (b == 1)return a;     else     {          if (b % 2 == 0)          {              ll t = quickpow(a, b / 2, n);              return t * t%n;          }          else          {              ll t = quickpow(a, b / 2, n);              t = t * t%n;              return t * a%n;          }     } } int main() {     get_C(3000);     ll a, b, k, n, m;     cin >> a >> b >> k >> n >> m;     //cout << quickpow(a, n, mod) << " " << quickpow(b, m, mod) << " " << C[k][n] % mod << endl;     cout << ((quickpow(a, n, mod)*quickpow(b, m, mod)) % mod*C[k][n] % mod) % mod<<endl;     //cout << C[1000][500]; } //829231 1000000 1000 500 500 //6880

 


最新回复(0)