HDU-1695 莫比乌斯反演
这里学习一下莫比乌斯反演
翻看了很多书,发现莫比乌斯反演,准确来说不是一种固有的公式,而是一种法则。
我们定义F(n),为f(d)的和函数,而定义f(n)为某儿算术函数。
反演公式1:反演n的因子时
废话不用多说,直接引入题目:
HDU-1695-GCD
给出a,b,c,d,k,
问[a,b]和[c,d]区间内部有多少不同的gcd(x,y)=k的对数目。
那么我们可以把GCD(x,y)进行分解。
由于某两个数的GCD是k,那么把这两个数除以K,那么这两个数的值,一定互质。那么我们可以这样。把区间变为[a/k,b/k],找到这个区间内部,GCD(X,Y)==1的对数。
怎么用好反演函数呢??
首先我们要把F(n)和f(d)的意义赋予好的定义。
这道题要求的是对数,那么求和函数F(d)为 有多少对(x,y)满足 gcd(x,y)== d 的倍数 。f(d)为有多少对(x,y)满足 gcd(x,y)== d 。
很明显,我们需要用
这样理解,F(n)代表gcd(x,y)==n的倍数的个数,它的值其实等于所有n的倍数d的gcd(x,y)==d组数的和。
这样我们就成功反演了。并且我们需要的是gcd(x,y)=1那么带入n=1,那么这个值就非常容易算了,我们
就只需要算当d=i时,他的F(i)是多少,这就是代码,这个区间内部,gcd(x,y)==k*i(意思是gcd(x,y)为i及其倍数的)个数,这个其实就非常简单了,n/i * m/i即可,意思是x在一个范围内所有i的倍数,乘以y能取到的所有i的倍数的个数相乘,就是答案,最后做和。不过题目忽略了(x,y)和(y,x)那么我们需要在相同区间的就是能取到(x,y)(y,x)的部分,重新计算这个值,然后除以2即可。
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#define LL long long
using namespace std;
const int maxn = +;
const int INF = 0x3f3f3f3f;
int miu[maxn];
bool vis[maxn];
int prime[maxn];
int mu[maxn];
int a,b,c,d,k;
void init(){
int M=maxn;
memset(prime,,sizeof(prime));
memset(mu,,sizeof(mu));
memset(vis,,sizeof(vis));
mu[]=;
int cnt=;
for (int i=;i<maxn;i++){
if (!vis[i]){//质数
prime[cnt++]=i;
mu[i]=-;//质数的mobius为-1
}
for (int j=;j<cnt && i*prime[j]<maxn ;j++){
vis[i*prime[j]]=;//筛掉
if (i%prime[j])mu[i*prime[j]]=-mu[i];
else {
mu[i*prime[j]]=;
break;
}
}
}
}
int main(){
int t;
scanf("%d",&t);
int ca=;
init();
while(t--){
ca++;
scanf("%d%d%d%d%d",&a,&b,&c,&d,&k);
if (k==){
printf("Case %d: 0\n",ca);
continue;
}
if (b>d)swap(b,d);
b=b/k;
d=d/k;
LL ans1=,ans2=;
for (int i=;i<=b;i++){
ans1+=(LL)mu[i]*(b/i)*(d/i);
}
for (int i=;i<=b;i++){
ans2+=(LL)mu[i]*(b/i)*(b/i);
}
printf("Case %d: %lld\n",ca,ans1-ans2/);
}
return ;
}
HDU-1695 莫比乌斯反演的更多相关文章
- HDU 1695 (莫比乌斯反演) GCD
题意: 从区间[1, b]和[1, d]中分别选一个x, y,使得gcd(x, y) = k, 求满足条件的xy的对数(不区分xy的顺序) 分析: 虽然之前写过一个莫比乌斯反演的总结,可遇到这道题还是 ...
- GCD HDU - 1695 莫比乌斯反演入门
题目链接:https://cn.vjudge.net/problem/HDU-1695#author=541607120101 感觉讲的很好的一个博客:https://www.cnblogs.com/ ...
- hdu 1695(莫比乌斯反演)
GCD Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- HDU 4746 (莫比乌斯反演) Mophues
这道题看巨巨的题解看了好久,好久.. 本文转自hdu4746(莫比乌斯反演) 题意:给出n, m, p,求有多少对a, b满足gcd(a, b)的素因子个数<=p,(其中1<=a<= ...
- HDU 5212 莫比乌斯反演
Code Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submis ...
- HDU 6053(莫比乌斯反演)
题意略. 思路:首先想到暴力去扫,这样的复杂度是n * min(ai),对于gcd = p,对答案的贡献应该是 (a1 / p) * (a2 / p) * .... * (an / p),得出这个贡献 ...
- hdu 4746Mophues[莫比乌斯反演]
Mophues Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 327670/327670 K (Java/Others) Total ...
- 算术 HDU - 6715 (莫比乌斯反演)
大意: 给定$n,m$, 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^m\mu(lcm(i,j))$ 首先有$\mu(lcm(i,j))=\mu(i)\mu(j)\m ...
- HDU 4746 莫比乌斯反演+离线查询+树状数组
题目大意: 一个数字组成一堆素因子的乘积,如果一个数字的素因子个数(同样的素因子也要多次计数)小于等于P,那么就称这个数是P的幸运数 多次询问1<=x<=n,1<=y<=m,P ...
- HDU 5382 莫比乌斯反演
题目大意: 求S(n)的值 n<=1000000 这是官方题解给出的推导过程,orz,按这上面说的来写,就不难了 这里需要思考的就是G(n)这个如何利用积性函数的性质线性筛出来 作为一个质数,那 ...
随机推荐
- 分享几个有趣的Linux命令
前言 最近工作比较忙,没时间写博客,这次介绍几个有趣的Linux命令. 命令:sl 当你使用这个命令时会看到一辆小火车从你的屏幕经过.亲测! 安装命令如下: yum -y install sl 执行效 ...
- [java]static关键字的四种用法
在java的关键字中,static和final是两个我们必须掌握的关键字.不同于其他关键字,他们都有多种用法,而且在一定环境下使用,可以提高程序的运行性能,优化程序的结构.下面我们先来了解一下stat ...
- Java开发笔记(二十一)二维数组的扩展
前面介绍的数组容纳的是一串数字,仿佛一根线把这组数字串了起来,故而它只是一维数组.一维数组用来表示简单的数列尚可,要是表达复杂的平面坐标系,那就力不从心了.由于平面坐标系存在水平和垂直两个方向,因此可 ...
- Asp.Net MVC @Html.TextBox 只允许输入数字问题
转到Html.TextBox()看可以看出 Html.TextBox()方法,创建文本框[<input type="text"/>],并且可以带上name,value和 ...
- Android为TV端助力 进制互相转换
byte转换为16进制 public static String GetByte2Str(byte b) { byte[] buff = new byte[2]; buff[0] = mHex[(b ...
- AndroidTV端的requestFocus()问题
每次开机盒子或者电视的时候,发现给某些控件设置请求焦点 requestFocus 会失效 最终的解决办法就是延时请求 view.postDelayed(new Runnable() { @Overri ...
- C# Math的说有函数 以及说明
Math.Abs(x) x绝对值 Math.Acos(x) ...
- EF ORM
//新增 UserInfo userInfo = new UserInfo(); userInfo.UserName = "YANG"; userInfo.UserPass = & ...
- OV摄像头图像采集基础知识总结
目前FPGA用于图像采集 传输 处理 显示应用越来越多,主要原因是图像处理领域的火热以及FPGA强大的并行处理能力.本文以OV7725为例,对摄像头使用方面的基础知识做个小的总结,为后续做个铺垫. 下 ...
- java反射(java.lang.reflect) ---普通单例模式唯一性问题
1. 普通的饱汉式.饿汉式 package org.bighead.test2; public class TestPrivate { private String str = "strPr ...