【洛谷2257/BZOJ2820】YY的GCD(数论/莫比乌斯函数)
题目:
预备知识:莫比乌斯定理(懵逼乌斯定理)
\(\mu*1=\epsilon\)(证bu明hui略zheng)
其中(我校学长把\(\epsilon(x)\)叫单位函数但是为什么我没百度到qwq)
0 & x\neq1\\
\end{cases}\]
0 & 存在质数p使p^2|x\\
(-1)^k & k是x质因数的个数 \end{cases}\]
那个\(*\)是迪利克雷卷积,换成人话就是
\]
我觉得用这种方式理解莫比乌斯定理比设两个函数容易
分析:
这题莫比乌斯定理的经典用例。
本文中默认\(N>M\)
默认\(p\)是质数
显然如果\(gcd(i,j)=p\),那么\(gcd(\frac{i}{p}, \frac{j}{p})=1\)
那么题目所求可以转换成下面的式子
\]
其中(我校学长把这个叫单位函数但是我没百度到qwq)
0 & x\neq1\\
\end{cases}\]
根据莫比乌斯反演定理,上面的式子就可以变成
\]
改变一下枚举顺序,用\(d·i\)表示原来的\(i\),\(d·j\)表示原来的\(j\),得到
\]
可以发现\(\mu(d)\)和\(i\)、\(j\)没半毛钱关系,仅仅是乘上\(i\)和\(j\)可以取的值的数量
也就是
\]
令\(T=pd\),枚举T,上式可变成
\]
设$$g(x)=\sum_{p|x}\mu(\frac{x}{p})$$
则上式就是
\]
现在考虑如何求\(g(x)\)这个函数。
首先,对于任意质数\(p\),显然\(g(p)=\mu(1)=1\)
然后,对于任意合数\(n=kp_0\)(\(p_0\)是质数)\(g(n)\)中显然存在\(\mu(\frac{n}{p_0})\)也就是\(\mu(k)\)这一项
当\({p_0}|k\),也就是\(p_0^2|n\),对于任意\(p|k\)且\(p\neq p_0\),\(\mu(\frac{n}{p})\)中一定有\(p_0^2\)这个质数平方因子。根据\(\mu(x)\)的定义,\(\mu(\frac{n}{p})=0\)
所以此时\(g(n)=\mu(k)\)
当\(p_0\)不能整除\(k\),对于任意\(p|k\),\(\mu(\frac{n}{p})\)比\(\mu(\frac{k}{p})\)多了\(p_0\)这个质因子。根据\(\mu(x)\)的定义\(\mu(\frac{n}{p})=-\mu(\frac{k}{p})\)
所以此时\(g(n)=-g(k)+\mu(k)\)
总结一下
\mu(k) & x=kp且p能整除k\\
-g(k)+\mu(k) & x=kp且p不能整除k
\end{cases}\]
显然这个函数可以用线性筛求
\]
再来看这个式子,既然\(g(T)\)可以直接预处理并\(O(1)\)查询,那么计算这个式子的时间复杂度就是枚举\(T\)的复杂度\(O(N)\)
我会做啦!
别急,这题还有\(T\)组询问,所以复杂度是O(不可过)\(O(NT)\),这个过不了。
但是我们可以发现\(\lfloor\frac{N}{T}\rfloor*\lfloor\frac{M}{T}\rfloor\)在\(T\)的一段区间内是不变的,所以可以给\(g(T)\)算个前缀和然后分段计算,据说复杂度是\(O(\sqrt N T)\)的(我不会证),这样就可以过了
代码:
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
namespace zyt
{
typedef long long ll;
const int N = 1e7 + 10, M = 7e5;
bool mark[N];
int cnt, prime[M], phi[N], mu[N];
ll g[N];
void init()
{
mu[1] = 1;
for (int i = 2; i < N; i++)
{
if (!mark[i])
prime[cnt++] = i, mu[i] = -1, g[i] = 1;
for (int j = 0; j < cnt && (ll)i * prime[j] < N; j++)
{
int k = i * prime[j];
mark[k] = true;
if (i % prime[j] == 0)
{
mu[k] = 0;
g[k] = mu[i];
break;
}
else
{
mu[k] = -mu[i];
g[k] = -g[i] + mu[i];
}
}
}
for (int i = 2; i < N; i++)
g[i] += g[i - 1];
}
void work()
{
int T;
init();
scanf("%d", &T);
while (T--)
{
int n, m, pos = cnt;
ll ans = 0;
scanf("%d%d", &n, &m);
if (n > m)
swap(n, m);
for (int t = 1; t <= n;)
{
int tmp = min(n / (n / t), m / (m / t));
ans += (g[tmp] - g[t - 1]) * (n / t) * (m / t);
t = tmp + 1;
}
printf("%lld\n", ans);
}
}
}
int main()
{
zyt::work();
return 0;
}
【洛谷2257/BZOJ2820】YY的GCD(数论/莫比乌斯函数)的更多相关文章
- 【洛谷2257】YY的GCD(莫比乌斯反演)
点此看题面 大致题意: 求\(\sum_{x=1}^N\sum_{y=1}^MIsPrime(gcd(x,y))\). 莫比乌斯反演 听说此题是莫比乌斯反演入门题? 一些定义 首先,我们可以定义\(f ...
- BZOJ2820 YY的GCD 【莫比乌斯反演】
BZOJ2820 YY的GCD Description 神犇YY虐完数论后给傻×kAc出了一题给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, ...
- LOJ #2185 / 洛谷 P3329 - [SDOI2015]约数个数和(莫比乌斯函数)
LOJ 题面传送门 / 洛谷题面传送门 题意: 求 \(\sum\limits_{i=1}^n\sum\limits_{j=1}^md(ij)\),\(d(x)\) 为 \(x\) 的约数个数. \( ...
- 洛谷 P2257 【YY的GCD】
这道题还是和上一道[ZAP]有那么一点点的相似哈 题目大意 给定N, M,求1<=x<=N, 1<=y<=M且\(gcd(x, y)\)为质数的(x, y)有多少对 如果对莫比 ...
- 【洛谷P2257】YY的GCD
题目大意:有 \(T\) 个询问,每个询问给定 \(N, M\),求 \(1\le x\le N, 1\le y\le M\) 且 \(gcd(x, y)\) 为质数的 \((x, y)\) 有多少对 ...
- BZOJ 2820 YY的GCD(莫比乌斯函数)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2820 题意:给定n,m.求1<=x<=n, 1<=y<=m且Gc ...
- 【BZOJ2820】YY的GCD(莫比乌斯反演)
[BZOJ2820]YY的GCD(莫比乌斯反演) 题面 讨厌权限题!!!提供洛谷题面 题解 单次询问\(O(n)\)是做过的一模一样的题目 但是现在很显然不行了, 于是继续推 \[ans=\sum_{ ...
- [BZOJ2820]YY的GCD
[BZOJ2820]YY的GCD 试题描述 神犇YY虐完数论后给傻×kAc出了一题给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, y)有多少 ...
- BZOJ2820 YY的GCD 莫比乌斯+系数前缀和
/** 题目:BZOJ2820 YY的GCD 链接:http://www.cogs.pro/cogs/problem/problem.php?pid=2165 题意:神犇YY虐完数论后给傻×kAc出了 ...
随机推荐
- 【Python实践-8】和为S的两个数字
(剑指offer)输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 思路:选定第一个数字,然后遍历后面的数字求和并与S比 ...
- plotting and saving over line in paraView
probe -- provides the field values in a particular location in space To save plotoverline to csv fil ...
- 被 idea 坑了的记录篇
这个星期真的是波折的一周~~~~ 不得不吐槽下无敌坑的自己了,社会我娜姐,坑起来连自己都坑~~ 其实这也不全算我自己的坑,我只是卸载了idea,重新装了一下而已,很神奇的把idea的几个坑全撞了一遍( ...
- POJ 1655 Balancing Act && POJ 3107 Godfather
题目大意: 根据题目的图很好理解意思,就是记录每一个点的balance,例如 i 的balance就是把 i 从这棵树中除去后得到的森林中含有结点数最多 的子树中的节点个数,然后找到所有节点中对应的b ...
- Neo4j ETL工具快速上手:简化从关系数据库到图数据库的数据迁移
注:本文系从https://medium.com/neo4j/tap-into-hidden-connections-translating-your-relational-data-to-graph ...
- [Usaco2015 dec]Max Flow
Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 204 Solved: 129[Submit][Status][Discuss] Descriptio ...
- [转] python 获取本机ip地址的两种实现方法
#!/usr/bin/python import socket import fcntl import struct def get_ip_address(ifname): s = socket.so ...
- Vue插槽的另外一些特性
之前有个项目,想判断一下,某一个模板内的插槽是否被使用. 不知道是不是问题过于简单,网上没有这方面的说明.我就抽时间验证一下vue插槽相关的一些功能. 然后写下这篇随笔,希望对后来人能有一些帮助. 简 ...
- Node.js 博客实例(三)添加文件上传功能
原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第三章 上传文件眼下有三种方法: 使用 Express 自带的文件上传功能,不涉及数据库 使用 For ...
- 「五」创建一个带 tomcat 服务的基础镜像(修订版)
Tomcat Tomcat 简单介绍 Tomcat server是一个免费的开放源码的Web 应用server,属于轻量级应用server.在中小型系统和并发訪问用户不是非常多的场合下被普遍使用,是开 ...