vjudge链接
原题链接
乍一看似乎没什么思路,但是写几个简单的例子之后规律就变得很明显。
比如当 n=5 时,每一步计算后的结果如下:
a1
a1+a2
a1+2a2+a3
a1+3a2+3a3+a4
a1+4a2+6a3+4a4+a5
显然系数“1, 4, 6, 4, 1”就是杨辉三角第五行。
故某一项的系数是否是题中 m 的倍数,就决定了最终得到的数除以 n 的余数和那一项是否有关。
二项式定理:
从中很容易得到前后两项的关系 C(n, k)=(n-k+1)/k*C(n, k-1)
。但是单纯用这个公式暴力得到每个系数一定会导致溢出,故需要运用唯一分解定理分别存储每个系数的素因数和指数。
一般的代码不难给出,但是一直TLE。最后发觉应该先分解 m ,再得到 m 的素因数在各个 C(n,k) 中的指数,若指数过小则可以提前结束当前的分解。由于 m>1 ,可以忽略 n==k 和 n==0 的情况。
我的 AC 代码如下,最初是用 ANSI C 写的,一步一步改过来,故非常不简洁。其中用 map 存储素因数,其中元素 -1 用来作为该项是否能被 m 整除的 flag。
/*
*lang C++ 5.3.0
*user Weilin_C
*/
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
by SDUST weilinfox
本文链接:https://www.cnblogs.com/weilinfox/p/12241600.html