10pts
暴力算不解释,时间复杂度O(kn+k2)。
30pts
我们观察到n很大,杨辉三角会T,直接算会上溢,所以需要预处理出1~k逆元再算,时间复杂度O(kn+nlogk+n2)或O(kn+n+k+n2)。
60pts
代入几个k,发现数列通项是一个多项式,故Sn也有一个通项;观察次数,可知an等于一个k次多项式,那么Sn等于一个k+1次方多项式,拉格朗日插值+高斯消元解出Sn表达式即可,当然也要预处理逆元,时间复杂度为O(k3)。
80pts
不要被n吓到,还是先算表达式,代入时高精度取模即可,时间复杂度为O(k3+klgn),其中lg为以10为底的对数。
100pts
手推!发现Sn=Cn+kk+1,那么就可以O(klgn)出答案了。