HDU 6053 TrickGCD 莫比乌斯函数/容斥/筛法
题意:给出n个数$a[i]$,每个数可以变成不大于它的数,现问所有数的gcd大于1的方案数。其中$(n,a[i]<=1e5)$
思路:鉴于a[i]不大,可以想到枚举gcd的值。考虑一个$gcd(a_1,a_2,a_3…a_n)=d$,显然每个$a_i$的倍数都满足,有$\frac{a_i}{d}$种方案
那么一个d对答案的贡献为\[\prod_{i=1}^{min(a)}{\lfloor\frac{a_i}{d}\rfloor} \]
但是所有的d计入会有重复情况,考虑容斥,对d进行素数分解,发现重复情况就是d的互异素数个数为偶数的,或是素数的指数大于1的。
然后会发现这情况的系数和莫比乌斯函数定义很像$(-f(d)) = \mu(d)=(-1)^k, d={p_1}{p_2}…{p_k}$,$\mu(d) = 0,d为非1整数$
现在我们就要考虑如何快速求得一个d的贡献了,类似筛法的思想,由于a[i]不大,预处理出前缀和,sum[i]代表小于i的数的个数,将按方案数大小分块,累加$cnt^{sum[(cnt+1)*d-1]-sum[cnt*d-1]}$得到结果,乘上容斥系数即可。
\[ ans = \sum_{d=1}^{min(a)}{(-\mu(d)) \sum_{j=1}^{\lfloor \frac{min(a)}{d} \rfloor}{j^{\sum_{i=1}^{n}{[\lfloor \frac{a_i}{d} \rfloor = j]}} }} \]
也就是把上式j的指数前缀和优化了一下。
分块优化也是很常见的,和以前的数论组合题已经算简单了,我好鶸鶸鶸鶸鶸鶸阿
/** @Date : 2017-07-28 19:30:46
* @FileName: HDU 6053 莫比乌斯函数 容斥 1009.cpp
* @Platform: Windows
* @Author : Lweleth (SoungEarlf@gmail.com)
* @Link : https://github.com/
* @Version : $Id$
*/
#include <bits/stdc++.h>
#define LL long long
#define PII pair
#define MP(x, y) make_pair((x),(y))
#define fi first
#define se second
#define PB(x) push_back((x))
#define MMG(x) memset((x), -1,sizeof(x))
#define MMF(x) memset((x),0,sizeof(x))
#define MMI(x) memset((x), INF, sizeof(x))
using namespace std; const int INF = 0x3f3f3f3f;
const int N = 1e5+20;
const double eps = 1e-8;
const LL mod = 1e9 + 7; LL pri[N];
LL mu[N];
LL sum[N];
bool vis[N];
int c = 0; void mobius()
{
MMF(vis);
mu[1] = 1;
for(int i = 2; i < N; i++)
{
if(!vis[i])
pri[c++] = i, mu[i] = -1;
for(int j = 0; j < c && i * pri[j] < N; j++)
{
vis[i * pri[j]] = 1;
if(i % pri[j])
mu[i * pri[j]] = -mu[i];
else
{
mu[i * pri[j]] = 0;
break;
}
}
}
for(int i = 0; i < N; i++)
mu[i] *= -1;
} LL fpow(LL x, LL n)
{
LL ans = 1;
while(n > 0)
{
if(n & 1)
ans = ans * x % mod;
x = x * x % mod;
n >>= 1;
}
return ans;
} int n;
LL a[N]; int main()
{
int icase = 0;
int T;
cin >> T;
mobius();
while(T--)
{
MMF(sum);
scanf("%d", &n);
LL mi = INF;
LL ma = -1;
for(int i = 0; i < n; i++)
{
scanf("%lld", a + i);
mi = min(a[i], mi);
ma = max(a[i], ma);
sum[a[i]]++;
}
for(int i = 2; i <= ma; i++)
sum[i] += sum[i - 1]; LL ans = 0;
for(LL g = 2; g <= mi; g++)
{
if(mu[g] == 0)
continue;
LL t = 1;
LL cnt = 1;
while(true)
{
int l = min(cnt * g, ma);
int r = min((cnt + 1) * g - 1, ma);
if(r > l - 1)
t = (t * fpow(cnt, sum[r] - sum[l - 1]) % mod + mod) % mod;
if(r == ma)
break;
cnt++;
}
//cout << t <<endl;
ans = (ans + mu[g] * t + mod) % mod;
}
while(ans < 0)
ans += mod;
printf("Case #%d: %lld\n", ++icase, ans);
}
return 0;
}
HDU 6053 TrickGCD 莫比乌斯函数/容斥/筛法的更多相关文章
- HDU 6053 ( TrickGCD )   分块+容斥
		
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
 - HDU 6053 TrickGCD (莫比乌斯函数)
		
题意:给一个序列A,要求构造序列B,使得 Bi <= Ai, gcd(Bi) > 1, 1 <= i <= n, 输出构造的方法数. 析:首先这个题直接暴力是不可能解决的,可以 ...
 - hdu 6390 欧拉函数+容斥(莫比乌斯函数) GuGuFishtion
		
http://acm.hdu.edu.cn/showproblem.php?pid=6390 题意:求一个式子 题解:看题解,写代码 第一行就看不出来,后面的sigma公式也不会化简.mobius也不 ...
 - C - Visible Trees HDU - 2841 -莫比乌斯函数-容斥
		
C - Visible Trees HDU - 2841 思路 :被挡住的那些点(x , y)肯定是 x 与 y不互质.能够由其他坐标的倍数表示,所以就转化成了求那些点 x,y互质 也就是在 1 - ...
 - Tmutarakan Exams URAL - 1091(莫比乌斯函数 ||  容斥)
		
题意: 求1 - s 中 找出k个数 使它们的gcd > 1 求这样的k个数的对数 解析: 从每个素数的倍数中取k个数 求方案数 然后素数组合,容斥一下重的 奇加偶减 莫比乌斯函数的直接套模 ...
 - BZOJ 2440 莫比乌斯函数+容斥+二分
		
2440: [中山市选2011]完全平方数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 5473 Solved: 2679[Submit][Sta ...
 - F - Tmutarakan Exams URAL - 1091 -莫比乌斯函数-容斥 or DP计数
		
F - Tmutarakan Exams 题意 : 从 < = S 的 数 中 选 出 K 个 不 同 的 数 并 且 gcd > 1 .求方案数. 思路 :记 录 一 下 每 个 数 的 ...
 - Relatively Prime Powers CodeForces - 1036F  (莫比乌斯函数容斥)
		
Relatively Prime Powers CodeForces - 1036F Consider some positive integer xx. Its prime factorizatio ...
 - 完全平方数 HYSBZ - 2440  (莫比乌斯函数容斥)
		
完全平方数 HYSBZ - 2440 小 X 自幼就很喜欢数.但奇怪的是,他十分讨厌完全平方数.他觉得这些 数看起来很令人难受.由此,他也讨厌所有是完全平方数的正整数倍的数.然而 这丝毫不影响他对其他 ...
 
随机推荐
- Team Work总结 && OPP课程总结
			
团队作业总结 工作总结 本次大作业我在团队内的工作是:根据框架构建实现建筑类的功能,包括防御塔.水晶.泉水等建筑.根据架构框架以及结合各建筑的特点,利用继承和多态很快速的解决了一些基本的问题.然而在实 ...
 - lintcode-382-三角形计数
			
382-三角形计数 给定一个整数数组,在该数组中,寻找三个数,分别代表三角形三条边的长度,问,可以寻找到多少组这样的三个数来组成三角形? 样例 例如,给定数组 S = {3,4,6,7},返回 3 其 ...
 - java程序连接MySQL数据库
			
驱动程序:mysql-connector-java-5.1.7-bin.jar. 程序示例如下: package commonProject; import java.sql.Connection; ...
 - Servlet中常用对象及API类之间的关系
			
Servlet最常用的对象: 请求对象:ServletRequest和HttpServletRequest,通过该对象获取来自客户端的请求信息 响应对象:ServletResponse和HttpSer ...
 - 探究Android中通过继承ViewGroup自定义控件的原理
			
原文地址:http://www.cnblogs.com/kross/p/3378395.html 今天断断续续的折腾了一下午到现在20:38,终于有点明白了.o(╯□╰)o 在Android开发中,我 ...
 - 使用salt-cloud创建虚拟机
			
salt-cloud也是基于openstack来做的,它可以支持多种云的使用.比如:Aliyun.Azure.DigitalOcean.EC2.Google Compute Engine.HP Clo ...
 - SQL入门之集合操作
			
尽管可以在与数据库交互时一次只处理一行数据,但实际上关系数据库通常处理的都是数据的集合.在数学上常用的集合操作为:并(union),交(intersect),差(except).对于集合运算必须满足下 ...
 - bzoj4754[JSOI2016]独特的树叶
			
这个题....别人写得怎么都....那么短啊? 我怎么....WA了好几次啊....怎么去loj扒了数据才调出来啊? 这个算法...怎么我还是不知道对不对啊 怎么回事啊怎么回事啊怎么回事啊? 请无视上 ...
 - Contest 9
			
A:搜索好难啊根本不会啊. B:暴力枚举给哪段前缀乘,维护一些前后缀最大最小值之类的东西就很好算了. #include<iostream> #include<cstdio> # ...
 - [BZOJ1588][HNOI2002]营业额统计 无旋Treap
			
[HNOI2002]营业额统计 时间限制: 5 Sec 内存限制: 162 MB 题目描述 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以 ...