首页 > 其他 > 详细

莫比乌斯反演

时间:2018-09-13 19:12:26      阅读:192      评论:0      收藏:0      [点我收藏+]

技术分享图片

学习链接:https://www.cnblogs.com/peng-ym/p/8647856.html

莫比乌斯函数线性筛代码:

 1 bool not_prime[maxn];
 2 int prime[maxn];
 3 int Mob[maxn];
 4 void Mobius_sieve(int n)
 5 {
 6     int tot = 0;
 7     not_prime[1] = 1;
 8     Mob[1] = 1;
 9     for(int i = 2; i <= n; i++)
10     {
11         if(!not_prime[i])prime[tot++] = i, Mob[i] = - 1;
12         for(int j = 0; j < tot && 1LL * prime[j] * i <= n; j++)
13         {
14             not_prime[prime[j] * i] = 1;//每个合数x由它最小素因子prime[j]筛掉
15             Mob[i * prime[j]] = (i % prime[j] ? -Mob[i]: 0);
16             if(i % prime[j] == 0)break;//如果i % prime[j] == 0,不停止循环
17             //那么接下来将用prime[j+1]筛去i*prime[j+1],但实际上应该用prime[i]筛去,因为i%prime[j]==0
18         }
19     }
20 }

 

莫比乌斯反演

原文:https://www.cnblogs.com/fzl194/p/9642117.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!