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

    你可能感兴趣的文章
    PHP 过滤器(Filter)
    查看>>
    php 运算符and or && || 的详解
    查看>>
    php 返回html字符串长度限制,记一次js中和php中的字符串长度计算截取的终极问题和完美...
    查看>>
    php 阿里云oss 上传回调
    查看>>
    PHP 面向对象 final类与final方法
    查看>>
    php+JQ+EasyUI自动加载数据
    查看>>
    php+sql server根据自增序号id区间查询第几条到第几条的数据
    查看>>
    php--------获取当前时间、时间戳
    查看>>
    php--正则表达式
    查看>>
    php--防止sql注入的方法
    查看>>
    PHP-CGI Windows平台远程代码执行漏洞复现(CVE-2024-4577)
    查看>>
    php-cgi耗尽报502错误
    查看>>
    php-cgi(fpm-cgi) 进程 CPU 100% 与 file_get_content...
    查看>>
    PHP-DI/Invoker 开源项目使用教程
    查看>>
    php-fpm与Nginx运行常见错误说明
    查看>>
    php-fpm比php成为apache模块好在哪
    查看>>
    php-fpm超时时间设置request_terminate_timeout分析
    查看>>
    php-fpm进程数优化
    查看>>
    PHP-GD库-分类整理
    查看>>
    php-laravel框架用户验证(Auth)模块解析(一)
    查看>>