博客
关于我
莫比乌斯反演
阅读量: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——distinct的用法
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的rownum 和rowid的用法和区别
    查看>>
    oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle监听配置、数据库实例配置等
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    Oracle计划将ZGC项目提交给OpenJDK
    查看>>
    Oracle闪回技术(Flashback)
    查看>>
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>
    oracle零碎要点---oracle em的web访问地址忘了
    查看>>
    Oracle零碎要点---多表联合查询,收集数据库基本资料
    查看>>