HDU 6053 - TrickGCD | 2017 Multi-University Training Contest 2
/*
HDU 6053 - TrickGCD [ 莫比乌斯函数,筛法分块 ] | 2017 Multi-University Training Contest 2
题意:
给出数列 A[N],问满足:
1 <= B[i] <= A[i] ;
对任意(l, r) (1<=l<=r<=n) ,使得 gcd(bl,...br) >= 2 ;
的 B[N] 数列的个数
分析:
设 gcd(b1,...bn) = k (k >= 2),此时 k 对答案的贡献为 (a1/k)*(a2/k)*(a3/k)*...*(an/k)
根据容斥原理,ans = +[k=一个素数之积 时对答案的贡献]
-[k=两个素数之积 时对答案的贡献]
+[k=三个素数之积 时对答案的贡献]
...
故任意k对答案的贡献系数 μ(k) = 0 , k是完全平方数的倍数
= (-1)^(n-1) , k = p1*p2*p3*...*pn ,p是素数
贡献系数可以O(nsqrt(n)) 或者 O(nlogn) 预处理,再或者可以看出μ(k) 是莫比乌斯函数的相反数 现在枚举k需要O(n)的时间,计算k对答案的贡献必须在O(sqrt(n))的时间之内
将a[]处理成权值数组,并求前缀和,设为 sum[]
对于每个k,对sum[]进行埃式筛法的分块,即根据k的倍数分块
此时每个k的贡献 = 1^(sum[2k-1]-sum[k-1]) * 2^(sum[3k-1]-sum[2k-1]) * 3^(sum[4k-1]-sum[3k-1]) ...
就做到 O(n(logn)^2) 编码时长: 40分钟(0)
*/
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const LL MOD = 1e9+7;
const int N = 1e5+4;
bool notp[N];
int prime[N], pnum, mu[N];
void Mobius() {
memset(notp, 0, sizeof(notp));
mu[1] = 1;
for (int i = 2; i < N; i++) {
if (!notp[i]) prime[++pnum] = i, mu[i] = -1;
for (int j = 1; prime[j]*i < N; j++) {
notp[prime[j]*i] = 1;
if (i%prime[j] == 0) {
mu[prime[j]*i] = 0;
break;
}
mu[prime[j]*i] = -mu[i];
}
}
for (int i = 0; i < N; i++) mu[i] = -mu[i];
}
LL PowMod(LL a, int m)
{
if (a == 1 || m == 0) return 1;
if (a == 0) return 0;
LL res = 1;
while (m)
{
if (m&1) res = res*a % MOD;
a = a*a % MOD;
m >>= 1;
}
return res;
}
int a[N];
int t, n;
int sum[N];
int Max, Min;
LL ans;
void solve()
{
int i, j, k, p;
ans = 0;
for (i = 2; i <= Min; ++i)
{
if (!mu[i]) continue;
LL res = 1;
j = min(i, Max), k = min((i<<1)-1, Max);
for (p = 1; ; ++p)
{
if (sum[k] - sum[j-1])
res = res*PowMod(p, sum[k] - sum[j-1]) % MOD;
if (k == Max) break;
j += i;
k += i;
if (k > Max) k = Max;
}
ans += mu[i]*res;
if (ans > MOD) ans -= MOD;
if (ans < 0) ans += MOD;
}
}
int main()
{
int i;
Mobius();
scanf("%d", &t);
for (int tt = 1; tt <= t; ++tt)
{
scanf("%d", &n);
for (i = 0; i < N; ++i) sum[i] = 0;
for (i = 1; i <= n; ++i)
{
scanf("%d", &a[i]);
++sum[a[i]];
}
Max = Min = a[1];
for (i = 2; i <= n; ++i)
{
Max = max(Max, a[i]);
Min = min(Min, a[i]);
}
for (i = 1; i <= Max; ++i) sum[i] += sum[i-1];
solve();
printf("Case #%d: %lld\n", tt, ans);
}
}
HDU 6053 - TrickGCD | 2017 Multi-University Training Contest 2的更多相关文章
- HDU 6053 TrickGCD —— 2017 Multi-University Training 2
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 6053: TrickGCD (2017 多校第二场 1009) 【莫比乌斯 容斥原理】
题目链接 定义f[n]表示n是最大公约数情况下的计数,F[n]为n是公约数情况下的计数 (可以和 http://www.cnblogs.com/Just--Do--It/p/7197788.html ...
- 2017 多校2 hdu 6053 TrickGCD
2017 多校2 hdu 6053 TrickGCD 题目: You are given an array \(A\) , and Zhu wants to know there are how ma ...
- 2017 Multi-University Training Contest - Team 2 &&hdu 6053 TrickGCD
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 6053 TrickGCD 筛法
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Probl ...
- hdu 6053 TrickGCD(筛法+容斥)
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU 6053 ( TrickGCD ) 分块+容斥
TrickGCD Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 4930 Fighting the Landlords--2014 Multi-University Training Contest 6
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4930 Fighting the Landlords Time Limit: 2000/1000 MS ...
- HDU 6168 - Numbers | 2017 ZJUT Multi-University Training 9
/* HDU 6168 - Numbers [ 思维 ] | 2017 ZJUT Multi-University Training 9 题意: .... 分析: 全放入multiset 从小到大,慢 ...
随机推荐
- 使用 WijmoJS 轻松实现撤消重做(Undo /Redo)
使用 WijmoJS 轻松实现撤消重做(Undo /Redo) 在V2019.0 Update2 的全新版本中,WijmoJS能够轻松实现撤消和重做操作,使Web应用程序的使用更加友好.更加高效. 不 ...
- QT 安卓动态获取权限
一:在AndroidManifest.xml文件中赋予相关权限 二: package ckdz.Appproject; import android.Manifest; import android. ...
- python检测域名
pip install python-whois import whois print(whois.whois('baidu.com')) #输出有关baidu.com的所有域名
- vue中params-解决换路由不刷新问题
因为依赖路由的params参数获取写在created生命周期里面,因为相同路由二次甚至多次加载的关系 没有达到监听,退出页面再进入另一个文章页面并不会运行created组件生命周期,导致文章数据还是第 ...
- Nginx如何配置防盗链
配置要点 none : 允许没有http_refer的请求访问资源: blocked : 允许不是http://开头的,不带协议的请求访问资源: 119.28.190.215 start.igrow. ...
- Mybatis Plus 使用详解
Mybatis Plus 是Mybatis的增强插件,对数据库操作Mybatis Plus提供了抽象层次比Mybatis更高的操作方法. Wrapper是Mybatis Plus里拼接sql的包装类. ...
- Gitlab创建ssh key并添加配置
1 生成ssh key zj改成你自己的邮箱或者名字之类的 ssh-keygen -t rsa -C "zj" 2 找到你生成的ssh key copy 公钥 添加到gitlab ...
- sql语句 小记录
select Name '姓名',Age '年龄',(select LessonName + ',' from Lesson where StudentId=s1.Id FOR XML PATH('' ...
- TextView跑马灯
TextView跑马灯 textView跑马灯实现:1.定义textView标签的4个属性:android:singleLine="true"//使其只能单行android:ell ...
- 7.Nginx_Keepalived高可用配置
2. 利用keepalived实现高可靠配置(HA) 2.1. 高可靠概念 HA(High Available):高可用性集群,是保证业务连续性的有效解决方案,一般有两个或两个以上的节点,且分为活动节 ...