博客
关于我
莫比乌斯反演
阅读量:234 次
发布时间:2019-03-01

本文共 1709 字,大约阅读时间需要 5 分钟。

为了解决问题,我们需要计算满足条件的数对 (x, y),使得 1 ≤ x ≤ N,1 ≤ y ≤ M,且 gcd(x, y) 是素数。我们可以利用莫比乌斯函数和包含-排除原理来高效地解决这个问题。

方法思路

  • 预处理莫比乌斯函数:莫比乌斯函数 μ(n) 将平方自由数标记为 ±1,非平方自由数标记为 0。我们可以通过筛法预处理 μ 数组。
  • 遍历质数:对于每个质数 p,计算满足条件的数对 (x, y) 的数量。
  • 包含-排除原理:对于每个质数 p,计算满足 x 和 y 都被 p 整除,但不能被 p² 整除的数对数量。利用莫比乌斯函数来处理平方因子。
  • 累加结果:将所有质数对应的数对数量累加,得到最终结果。
  • 解决代码

    #include 
    using namespace std;const int maxm = 1e6 + 5;int notprime[maxm];int prime[maxm], cnt;int mu[maxm];void Minit() { mu[1] = 1; for (int i = 2; i < maxm; ++i) { if (!notprime[i]) { prime[cnt++] = i; mu[i] = -1; } for (int j = 0; j < cnt; ++j) { if (prime[j] * i > maxm) break; notprime[prime[j] * i] = 1; mu[prime[j] * i] = (i % prime[j]) ? -mu[i] : 0; if (i % prime[j] == 0) break; } }}int main() { Minit(); int t; cin >> t; while (t--) { int N, M; cin >> N >> M; if (N == 0 || M == 0) { cout << 0 << endl; continue; } long long ans = 0; for (int p = 0; p < cnt; ++p) { int current_p = prime[p]; long long sum_p = 0; for (int k = 1; ; ++k) { if ((long long)k * current_p > maxm) break; if (mu[k] == 0) continue; int multiple = current_p * k; int a = N / multiple; int b = M / multiple; sum_p += mu[k] * a * b; } ans += sum_p; } cout << ans << endl; } return 0;}

    代码解释

  • 预处理莫比乌斯函数:使用筛法初始化 μ 数组,标记平方自由数和质数。
  • 遍历质数:对于每个质数 p,计算满足条件的数对数量。
  • 包含-排除原理:通过遍历 k,计算满足条件的数对数量,并利用莫比乌斯函数处理平方因子。
  • 累加结果:将所有质数对应的数对数量累加,得到最终结果并输出。
  • 这种方法高效地利用了莫比乌斯函数和包含-排除原理,确保了计算的准确性和效率。

    转载地址:http://qtzv.baihongyu.com/

    你可能感兴趣的文章
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:绘制带箭头的线
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers实战:非4326,3857的投影
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>