/*
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的更多相关文章

  1. HDU 6053 TrickGCD —— 2017 Multi-University Training 2

    TrickGCD Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  2. hdu 6053: TrickGCD (2017 多校第二场 1009) 【莫比乌斯 容斥原理】

    题目链接 定义f[n]表示n是最大公约数情况下的计数,F[n]为n是公约数情况下的计数 (可以和 http://www.cnblogs.com/Just--Do--It/p/7197788.html  ...

  3. 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 ...

  4. 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 ...

  5. hdu 6053 TrickGCD 筛法

    TrickGCD Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) Probl ...

  6. hdu 6053 TrickGCD(筛法+容斥)

    TrickGCD Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  7. HDU 6053 ( TrickGCD ) 分块+容斥

    TrickGCD Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  8. 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 ...

  9. HDU 6168 - Numbers | 2017 ZJUT Multi-University Training 9

    /* HDU 6168 - Numbers [ 思维 ] | 2017 ZJUT Multi-University Training 9 题意: .... 分析: 全放入multiset 从小到大,慢 ...

随机推荐

  1. SpringBoot2.x集成WebSocket

    WebSocket 不做过多得介绍,这里有篇比较全面得文章      Spring Boot系列十六 WebSocket简介和spring boot集成简单消息代理 我这里是精简版,只挑出核心代码记录 ...

  2. if(!ConnectDBProc(strCmd,m_dbUserName,m_dbPassword))

    https://wenku.baidu.com/view/826b3d426bec0975f565e204.html

  3. PAT A1035 Password (20)

    AC代码 注意创造函数条件中使用引用 输出语句注意单复数 #include <cstdio> #include <cstring> #include <iostream& ...

  4. Elastic Search常用元数据简介

    在ES中,除了定义的index,type,和管理的document外,还有若干的元数据.这些元数据用于记录ES中需要使用的核心数据.在ES中,元数据通常使用下划线’_’开头. 1 查看数据GET /i ...

  5. oracle按用户导出导入表

    查看备份目录:select * from dba_directories where directory_name='DATA_PUMP_DIR'; 导入导出的文件名默认都是以备份目录为相对路径. 按 ...

  6. springMVC 接受map参数的写法

    <form > <input type="hidden" name="map['userKey']" value="11111&qu ...

  7. lesson12Homework

    package StringPractice; public class arrayTest { //1. 把A数组的前5个元素复制到B数组中. public static void main(Str ...

  8. golang(8):channel读写 & goroutine 通信

    goroutine 1.进程和线程 A. 进程是程序在操作系统中的一次执行过程,系统进行资源分配和调度的一个独立单位 B. 线程是进程的一个执行实体,是CPU调度和分派的基本单位,它是比进程更小的能独 ...

  9. react的嵌套组件

    react没有vue插槽的概念,但是有嵌套组件,可以用嵌套组件实现类似插槽的功能.下例中,color,name,btn相当于具名插槽,children相当于匿名插槽. import React fro ...

  10. MFC 下调试 出现 warning : fail to load indicator string 0x0069

    MFC 下调试 出现 warning : fail to load indicator string 0x0069 就是程序状态栏每一个标识列中至少有一个值没有初始值 或初始值为空 导致程序没有获取到 ...