西格玛函数σ 线性筛求约数和

本文探讨了使用线性筛法求解约数和的问题,并指出该方法可以扩展到求积性函数。由于非完全积性,当两数不互质时不能直接相乘。在互质情况下,可以直接相乘。针对不互质的情况,作者提出了通过min_factory_a数组来记录数的最小质因子乘积,以便在遇到质因子时减去旧贡献并加上新贡献。

http://www.elijahqi.win/archives/1247
解法:待填坑

其实这个完全可以拓展到线性筛求积性函数

因为非完全积 所以在两数不互质的情况下不可以直接相乘

但是两数互质的情况下就可以直接相乘

下面需要讨论下不互质的情况 我设定一个数组min_factory_a表示我这个数的最小质因子乘起来是多少 因为非完全积性,那么其实我们每次枚举到i%prime[j]==0的时候就是因为这个prime[j](仔细考虑线性筛)的出现会导致答案有所不同 于是我们想办法把这部分的贡献都除掉 然后再乘以这部分+新的prime[j]后生成的新的贡献就可以了

#include<cstdio>
#define N 110000000
int sigma[N],min_factory_a[N],prime[N/10],not_prime[N],n; 
int main(){
    freopen("ex1.in","r",stdin);
    freopen("ex1.out","w",stdout);
    scanf("%d
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值