jzoj5224 [GDOI2018模拟7.12]C 杜教筛+自然数幂和

20 篇文章 0 订阅
9 篇文章 0 订阅

Description


i=1nj=1ngcd(i,j)kn1010k5 ∑ i = 1 n ∑ j = 1 n gcd ( i , j ) k 且 n ≤ 10 10 , k ≤ 5

Solution


这是一篇口胡题解,如果有什么错还请拍打喂食
很容易得到一个不那么显然的异于题解的柿子

ans=T=1nnT2d|Tμ(Td)dk a n s = ∑ T = 1 n ⌊ n T ⌋ 2 ∑ d | T μ ( T d ) ⋅ d k

注意到可以分块,然后后面是个狄利克雷卷积可以考虑怎么筛他

我们令 f(n)=nk f ( n ) = n k g(n)=n g ( n ) = n ,要求的函数为 h(n)=d|nμ(nd)dk h ( n ) = ∑ d | n μ ( n d ) ⋅ d k 那么有 h=fμ h = f ∗ μ

于是有焉 hg=f(μg)=f h ∗ g = f ∗ ( μ ∗ g ) = f ,f的前缀和可以轻易求,g也非常显然,那么我们就能杜教筛了

写成式子就是

d|nf(d)nd=nk ∑ d | n f ( d ) ⋅ n d = n k

i=1nd|if(d)id=d=1ndi=1ndf(i)=i=1nik ∑ i = 1 n ∑ d | i f ( d ) ⋅ i d = ∑ d = 1 n d ∑ i = 1 ⌊ n d ⌋ f ( i ) = ∑ i = 1 n i k

这是非常经典的形式

然后就是那个自然数幂和的问题。由于k不大可以用拉格朗日大炮打蚊子(我只会拉格朗日

Code


这是一篇口胡题解辣~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值