博客
关于我
莫比乌斯反演
阅读量: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/

    你可能感兴趣的文章
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>
    org.apache.poi.hssf.util.Region
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    orm总结
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    paddle的两阶段基础算法基础
    查看>>
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    pageHelper分页工具的使用
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>
    Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
    查看>>
    Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现
    查看>>
    pandas DataFrame 中的自定义浮点格式
    查看>>
    Pandas 对数据框的布尔比较
    查看>>
    Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
    查看>>