GuGuFishtion HDU - 6390 (欧拉函数,容斥)
GuGuFishtion
\]
题意
给出定义\(Gu(a, b) = \frac{\phi(ab)}{\phi(a)\phi(b)}\)
求出\(\sum_{a=1}^{m}\sum_{b=1}^{n}Gu(a,b) (mod p)\)
思路
首先对于欧拉函数,我们知道欧拉函数的朴素式子为:\(\phi(n) = n*(1-\frac{1}{p1})*(1-\frac{1}{p2}) * ... * (1-\frac{1}{pn})\),\(pi\) 为 \(n\) 的质因子。
对于任意两个数 \(a,b\),令 \(g = gcd(a, b)\)
- 若 \(g != 1\),令 \(pi\) 为 \(a\) 特有的质因子,\(qi\) 为 \(b\) 特有的质因子,\(ti\) 为\(a,b\) 共有的质因子,那么将 \(Gu(a, b)\) 展开,就可以得到
Gu(a, b) &= \frac{\phi(ab)}{\phi(a)\phi(b)}\\
&= \frac{ab \prod(1-\frac{1}{pi}) \prod(1-\frac{1}{ti}) \prod(1-\frac{1}{qi}) }{a \prod(1-\frac{1}{pi}) \prod(1-\frac{1}{ti}) b \prod(1-\frac{1}{qi})\prod(1-\frac{1}{ti})} \\
&= \frac{1}{\prod(1-\frac{1}{ti})}
\end{aligned}
\]
现在我们设 \(x\),\(x\) 包括了所有的 \(ti\),那么就有
Gu(a, b) &= \frac{1}{\prod(1-\frac{1}{ti})} \\
&= \frac{x}{x\prod(1-\frac{1}{ti})} \\
&= \frac{x}{\phi(x)}
\end{aligned}
\]
\(x\) 也很好知道是多少,其实 \(g\) 就满足同时包括了所有 \(ti\) 的数,所以我们可以设 \(x = g\),就可以得到 \(Gu(a,b) = \frac{g}{\phi(g)}\)。
2. 若 \(g=1\),此时不存在 \(ti\),但这是 \(Gu(a, b)\) 展开后全部消掉了,所以答案为 \(1\),而 \(\frac{1}{\phi(1)}\) 也正好为 \(1\),所以也可以看成 \(Gu(a,b) = \frac{g}{\phi(g)}\)。
综合上述,\(Gu(a,b) = \frac{g}{\phi(g)}\)。
此时我们只要计算出 \(gcd(a, b) = x (a\in [1,m], b\in[1,n])\) 的对数,就可以直接计算答案了。
这里可以利用经典的莫比乌斯反演,也可以利用容斥原理。
令:
\(f(i)\) 表示 \(gcd\) 等于 \(i的倍数\) 的对数
\(g(i)\) 表示 \(gcd\) 等于 \(i\) 的对数
那么就有
g(i) = f(i) - \sum_{j=2}^{i*j<=min(n,m)} g(ij)
\]
如此倒着计算 \(g(i)\),就可以得出答案。
Hint
emmmm,这题其实有点卡常,要注意取模的次数和自然数逆元打表的姿势。
/***************************************************************
> File Name : a.cpp
> Author : Jiaaaaaaaqi
> Created Time : 2019年08月26日 星期一 16时58分58秒
***************************************************************/
#include <map>
#include <set>
#include <list>
#include <ctime>
#include <cmath>
#include <stack>
#include <queue>
#include <cfloat>
#include <string>
#include <vector>
#include <cstdio>
#include <bitset>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <unordered_map>
#define lowbit(x) x & (-x)
#define mes(a, b) memset(a, b, sizeof a)
#define fi first
#define se second
#define pb push_back
#define pii pair<int, int>
typedef unsigned long long int ull;
typedef long long int ll;
const int maxn = 1e6 + 10;
const int maxm = 1e5 + 10;
const ll mod = 1e9 + 7;
const ll INF = 1e18 + 100;
const int inf = 0x3f3f3f3f;
const double pi = acos(-1.0);
const double eps = 1e-8;
using namespace std;
ll n, m;
int cas, tol, T;
int pri[maxn], phi[maxn];
bool ispri[maxn];
ll f[maxn], g[maxn], inv[maxn];
void handle() {
int mx = 1e6;
mes(ispri, 1);
tol = 0;
phi[1] = 1;
for(int i=2; i<=mx; i++) {
if(ispri[i]) {
pri[++tol] = i;
phi[i] = i-1;
}
for(int j=1; j<=tol&&i*pri[j]<=mx; j++) {
ispri[i*pri[j]] = 0;
if(i%pri[j] == 0) {
phi[i*pri[j]] = phi[i]*pri[j];
break;
} else {
phi[i*pri[j]] = phi[i]*(pri[j]-1);
}
}
}
}
int main() {
// freopen("in", "r", stdin);
handle();
inv[1] = 1;
scanf("%d", &T);
while(T--) {
ll p;
scanf("%lld%lld%lld", &n, &m, &p);
ll x = min(n, m);
for(int i=2; i<=x; i++) inv[i] = (p-p/i)*inv[p%i]%p;
for(int i=1; i<=x; i++) f[i] = (n/i)*(m/i)%p;
for(int i=x; i>=1; i--) {
g[i] = f[i];
for(int j=2; i*j<=x; j++) {
g[i] -= g[i*j];
if(g[i]<0) g[i]+=p;
}
}
ll ans = 0;
for(int i=1; i<=x; i++) {
ans += 1ll*g[i]*i%p * inv[phi[i]]%p;
ans %= p;
}
printf("%lld\n", ans);
}
return 0;
}
GuGuFishtion HDU - 6390 (欧拉函数,容斥)的更多相关文章
- hdu 6390 欧拉函数+容斥(莫比乌斯函数) GuGuFishtion
http://acm.hdu.edu.cn/showproblem.php?pid=6390 题意:求一个式子 题解:看题解,写代码 第一行就看不出来,后面的sigma公式也不会化简.mobius也不 ...
- HDU 1695 GCD 欧拉函数+容斥定理 || 莫比乌斯反演
GCD Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- hdu 1695 GCD(欧拉函数+容斥)
Problem Description Given 5 integers: a, b, c, d, k, you're to find x in a...b, y in c...d that GCD( ...
- HDU 1695 GCD 欧拉函数+容斥定理
输入a b c d k求有多少对x y 使得x在a-b区间 y在c-d区间 gcd(x, y) = k 此外a和c一定是1 由于gcd(x, y) == k 将b和d都除以k 题目转化为1到b/k 和 ...
- hdu1695(莫比乌斯)或欧拉函数+容斥
题意:求1-b和1-d之内各选一个数组成数对.问最大公约数为k的数对有多少个,数对是有序的.(b,d,k<=100000) 解法1: 这个能够简化成1-b/k 和1-d/k 的互质有序数对的个数 ...
- HDU1695-GCD(数论-欧拉函数-容斥)
GCD Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- HDU 6053 TrickGCD 莫比乌斯函数/容斥/筛法
题意:给出n个数$a[i]$,每个数可以变成不大于它的数,现问所有数的gcd大于1的方案数.其中$(n,a[i]<=1e5)$ 思路:鉴于a[i]不大,可以想到枚举gcd的值.考虑一个$gcd( ...
- hdu 2654(欧拉函数)
Become A Hero Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- hdu 2824(欧拉函数)
The Euler function Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- hdu 1395(欧拉函数)
2^x mod n = 1 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
随机推荐
- 【题解】整数划分 [51nod1201] 整数划分 V2 [51nod1259]
[题解]整数划分 [51nod1201] 整数划分 V2 [51nod1259] 传送门:整数划分 \([51nod1201]\) 整数划分 \(V2\) \([51nod1259]\)** [题目描 ...
- Linux学习笔记之LVM基本应用,扩展及缩减实现
0x00 LVM概述 LVM是逻辑盘卷管理(Logical Volume Manager)的简称,它是Linux环境下对磁盘分区进行管理的一种机制,LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘 ...
- 解决v-html无法理解vue模版的问题-动态获取模版,动态插入app并使用当下app状态数据需求
很多情况下,我们需要使用动态的html作为某个dom元素的inner html,如果这个内容是标准的html的话,则v-html能够圆满满足需求,而如果内容包含了vue组件,则使用v-html就不能达 ...
- Deepo
Deepo is a series of Docker images that allows you to quickly set up your deep learning research env ...
- Java自学-面向对象 类和对象
Java中的类和对象 引入面向对象的基本概念 假设,我们要设计一个LOL这样的游戏,使用面向对象的思想来设计,应该怎么做? 步骤 1 : 设计英雄这个类 LOL有很多英雄,比如盲僧,团战可以输,提莫必 ...
- 查看mysql字符集、修改数据库、数据表、字段字符集
查看所有表的字符集 SELECT table_name, table_type, engine, version, table_collation FROM information_schema.ta ...
- 为什么K8s会成为主流?
容器技术和K8s是云原生概念的核心和基础.云计算诞生已有超过10年,但云计算时代的应用到底该是什么样子,一直没人能说清楚,也没人能确定云计算的基础架构将会如何发展.在K8s出现之前,没人设想过会有一个 ...
- jQuery的内部运行机制和原理
jQuery的优点: jQuery是一个非常优秀的JavaScript库,与Prototype,YUI,Mootools等众多的Js类库相比,它剑走偏锋,从Web开发实用的角度出发,抛除了其它Lib中 ...
- Golang: 读写之外的其他文件操作
在上一篇文章中,我们介绍了常用的文件读写操作,今天接着来研究一下,除了读写以外的其他常见文件操作. 一.创建目录: package main import ( "fmt" &quo ...
- SQL 乐色干货笔记
因为公司基本都是用存储过程所以本来写的干货基本都是存储过程的. SELECT TOP 1 Code,Invitation,Num,Typ FROM SignLog WITH(NOLOCK) WHERE ...