洛谷团队月赛题:题解

本文解析了一个算法竞赛中不同分数段的解决方案,从暴力算法到高级的数学推导,详细介绍了如何通过多项式、拉格朗日插值和高斯消元等方法优化算法的时间复杂度。

10pts10pts10pts

暴力算不解释,时间复杂度O(kn+k2)O(kn+k^2)O(kn+k2)

30pts30pts30pts

我们观察到nnn很大,杨辉三角会T,直接算会上溢,所以需要预处理出111~kkk逆元再算,时间复杂度O(kn+nlogk+n2)O(kn+nlogk+n^2)O(kn+nlogk+n2)O(kn+n+k+n2)O(kn+n+k+n^2)O(kn+n+k+n2)

60pts60pts60pts

代入几个kkk,发现数列通项是一个多项式,故SnS_nSn也有一个通项;观察次数,可知ana_nan等于一个kkk次多项式,那么SnS_nSn等于一个k+1k+1k+1次方多项式,拉格朗日插值+高斯消元解出SnS_nSn表达式即可,当然也要预处理逆元,时间复杂度为O(k3)O(k^3)O(k3)

80pts80pts80pts

不要被nnn吓到,还是先算表达式,代入时高精度取模即可,时间复杂度为O(k3+klgn)O(k^3+klgn)O(k3+klgn),其中lg为以10为底的对数。

100pts100pts100pts

手推!发现Sn=Cn+kk+1S_n=C_{n+k}^{k+1}Sn=Cn+kk+1,那么就可以O(klgn)O(klgn)O(klgn)出答案了。

转载于:https://www.cnblogs.com/ShineEternal/p/10834278.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值