hdu6053
hdu6053
题意
给出 \(A\) 数组,问有多少种 \(B\) 数组满足下面条件。
- \(1≤ B_i ≤ A_i\)
- For each pair \(( l , r ) \ (1≤l≤r≤n) , gcd(b_l,b_{l+1}...b_r) ≥ 2\) 。
分析
首先肯定要去枚举 \(gcd\) ,如果暴力去计算,对于每个 \(gcd\) ,我们都要乘 \(n\) 次,这样显然会超时。考虑一种将区间分块的思想,如果 \(gcd\) 为 \(10\) ,那么区间 \([20, 30)\) 里的数除以 \(10\) 都是 \(2\) ,当 \(gcd\) 越大时,区间越大。我们直接统计下前缀和,可以查询某个区间里包含的数的个数,快速幂计算答案。
最后求得的 \(dp[i]\) 表示 \(gcd=i\) 时,构成的 \(B\) 数组的个数,可以用容斥去处理得到最后的答案。
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long ll;
const int MAXN = 1e5 + 10;
const int N = 1e5 + 5;
const ll MOD = 1e9 + 7;
int kase = 1;
int T;
ll POW(ll x, int n) {
ll res = 1;
while(n) {
if(n & 1) res = res * x % MOD;
x = x * x % MOD;
n >>= 1;
}
return res;
}
int sum[MAXN];
ll dp[MAXN];
int main() {
scanf("%d", &T);
while(T--) {
memset(sum, 0, sizeof sum);
memset(dp, 0, sizeof dp);
int n;
scanf("%d", &n);
int mn = N;
for(int i = 0; i < n; i++) {
int x;
scanf("%d", &x);
mn = min(mn, x);
sum[x]++;
}
for(int i = 1; i <= N; i++) {
sum[i] += sum[i - 1];
}
for(int i = 2; i <= mn; i++) {
ll c = 0;
dp[i] = 1;
for(int j = i; j <= N; j += i) {
c++;
int x;
if(j + i - 1 > N) x = sum[N] - sum[j - 1];
else x = sum[j + i - 1] - sum[j - 1];
if(x == 0) continue;
dp[i] = (dp[i] * POW(c, x)) % MOD;
}
}
for(int i = N; i >= 2; i--) {
for(int j = 2 * i; j <= N; j += i) {
dp[i] = (dp[i] - dp[j] + MOD) % MOD;
}
}
ll ans = 0;
for(int i = 0; i <= N; i++) {
ans = (ans + dp[i]) % MOD;
}
printf("Case #%d: %lld\n", kase++, ans);
}
return 0;
}
hdu6053的更多相关文章
- hdu6053 TrickGCD 容斥原理
/** 题目:hdu6053 TrickGCD 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6053 题意:You are given an array ...
- HDU-6053 TrickGCD
题目连接: https://vjudge.net/problem/HDU-6053 Description You are given an array A , and Zhu wants to kn ...
- [Hdu-6053] TrickGCD[容斥,前缀和]
Online Judge:Hdu6053 Label:容斥,前缀和 题面: 题目描述 给你一个长度为\(N\)的序列A,现在让你构造一个长度同样为\(N\)的序列B,并满足如下条件,问有多少种方案数? ...
- hdu6053(莫比乌斯+容斥+分块)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6053 题意: 给出一个含 n 个元素的 a 数组, 求 bi <= ai 且 gcd(b1, ...
- Codeforces #428 Div2 D
#428 Div2 D 题意 给出一些数,现在要求找出一些数满足 \(i_1 < i_2 < i_3 < ... < i_k\) 以及 \(gcd(a_{i_1}, a_{i_ ...
- Codeforces 803F - Coprime Subsequences(数论)
原题链接:http://codeforces.com/contest/803/problem/F 题意:若gcd(a1, a2, a3,...,an)=1则认为这n个数是互质的.求集合a中,元素互质的 ...
随机推荐
- CSS系列(8) CSS后代选择器和子选择器详解
一.CSS后代选择器详解 1, 生动介绍基本概念 一个标签嵌B在另一个标签A内部,B就是A的后代. 而且,B的后代也是A的后代,这就叫“子子孙孙无穷尽也”. 比如: <div> < ...
- 程序员必备PC维修法(硬件篇)
自检自修不是万能,但不会自检自修却万万不能.程序员修电脑还是有必要的. 情景:通电情况下,电脑主机无法启动,所有主机内部硬件无反应. 原因:1.CPU.主板.电源积尘.(出现率30%) 2.CPU.主 ...
- Pythonyield使用浅析
转自:https://www.ibm.com/developerworks/cn/opensource/os-cn-python-yield/ 您可能听说过,带有 yield 的函数在 Python ...
- Python 3基础教程8--if else、if elif else
本文介绍if else语句,不多说,直接看例子. if elif else语句
- App自动化测试前期准备---android SDK配置
说明:就是配置android SDK 一.sdk下载 Windows(X64):立即下载 Linux(X64):立即下载 二.Windows配置 1.解压文件 直接解压到指定目录(演示目录:D:/) ...
- input()报错:TypeError: '>=' not supported between instances of 'str' and 'int'
今天学习python基础—分支与循环,接触到了if.在练习一个if语句的时候,出现了错误. 题目是: 根据分数划分成四个级别:优秀.良好.及格.不及格,分数是72: grade = 72if grad ...
- web知识清单
声名随笔中的实例链接到另一个博客是我本人的另一个博客号 模块一:HTML 1.html是什么: hyperText markup language超文本标记语言 超文本:比文本更丰富的内容 所有的浏览 ...
- Android事件分发机制详解(2)----分析ViewGruop的事件分发
首先,我们需要 知道什么是ViewGroup,它和普通的View有什么区别? ViewGroup就是一组View的集合,它包含很多子View和ViewGroup,是Android 所有布局的父类或间接 ...
- .Net MVC断点进不去
.Net MVC断点进不去 1.httpget httppost 2.启动项设为UI 3.基于页面没错误的情况下
- [洛谷P4074][WC2013]糖果公园
题目大意:给一棵$n$个节点的树,每个点有一个值$C_i$,每次询问一条路径$x->y$,求$\sum\limits_{c}val_c\times \sum\limits_{i=1}^{cnt_ ...