码迷,mamicode.com
首页 > 其他好文 > 详细

莫比乌斯反演

时间:2018-09-13 20:05:52      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:target   分享   int   logs   bsp   https   函数   class   技术   

技术分享图片

学习链接: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 }

 

莫比乌斯反演

标签:target   分享   int   logs   bsp   https   函数   class   技术   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!