数论/莫比乌斯反演/快速mu前缀和


  比较容易想到令f[x]表示gcd=x的方案数,令g[x]表示x|gcd的方案数。

  那么有$ g(d)=\sum_{d|n} f(n)$,根据莫比乌斯反演,有$f(d)=\sum_{d|n} g(n)*\mu (\frac{n}{d})$

  我一开始想的是算出g以后,倒序枚举 i ,然后枚举 i 的倍数,递推出所有的f[i]……

  因为g比较好算嘛……快速幂一下什么的……

  然而$10^9$直接吓傻我。

  Orz PoPoQQQ

  快速求出mu的前缀和,$10^9$也照样不虚,太神辣

 /**************************************************************
Problem: 3930
User: Tunix
Language: C++
Result: Accepted
Time:4200 ms
Memory:54024 kb
****************************************************************/ //BZOJ 3930
#include<cstdio>
#include<map>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define pb push_back
using namespace std;
typedef long long LL;
inline int getint(){
int r=,v=; char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if (ch=='-') r=-;
for(; isdigit(ch);ch=getchar()) v=v*-''+ch;
return r*v;
}
const int N=1e7+,P=1e9+;
const int INF=0x3f3f3f3f;
/*******************template********************/ int mu[N],prime[],tot;
bool check[N];
map<int,LL> mu_sum;
LL n,d,l,r;
void getmu(){
int n=;
mu[]=;
F(i,,n){
if (!check[i]){
mu[i]=-;
prime[++tot]=i;
}
F(j,,tot){
int k=i*prime[j];
if (k>n) break;
check[k]=;
if (i%prime[j]) mu[k]=-mu[i];
else{
mu[k]=;
break;
}
}
}
F(i,,n) mu[i]+=mu[i-];
}
LL Mu_sum(int x){
if (x<=) return mu[x];
if (mu_sum.find(x)!=mu_sum.end())
return mu_sum[x];
LL i,last,re=;
for(i=;i<=x;i=last+){
last=x/(x/i);
if (x/i-)
re-=(Mu_sum(last)-Mu_sum(i-))*(x/i-);
}
return mu_sum[x]=re;
}
LL Pow(LL a,int b){
LL r=;
for(;b;b>>=,a=a*a%P) if (b&) r=r*a%P;
return r;
}
LL solve(){
LL i,last,re=;
for(i=;i<=r;i=last+){
last=min(r/(r/i),l/i?(l/(l/i)):INF);
re+=(Mu_sum(last)-Mu_sum(i-))*Pow(r/i-l/i,n);
re%=P;
}
return (re%P+P)%P;
}
int main(){
#ifndef ONLINE_JUDGE
freopen("3930.in","r",stdin);
freopen("3930.out","w",stdout);
#endif
n=getint(); d=getint(); l=getint(); r=getint();
l=(l-)/d; r=r/d;
getmu();
printf("%lld\n",solve());
return ;
}

  然而$H-L \leq 10^5$并没用?不是的……我们可以枚举倍数!

  Orz syk

  记f[i]为gcd恰好为$K*i$的选数方案数,那么对于每一个$i$记$L$为$\lceil \frac{a}{K*i}\rceil $,$R$为$\lfloor\frac{b}{K*i}\rfloor$ 那么他的方案数就为$f[i] = (R-L+1) ^ N - (R-L+1)-\sum_{a=1,2,\dots} f[a*i]$最后的f[1]即为答案。注意若$\lceil \frac{a}{K} \rceil == 1$ 那么全部选K也是一种方案,需要+1。

  (话说好不容易想到一次莫比乌斯反演,然而却做不出来……唉

 /**************************************************************
Problem: 3930
User: Tunix
Language: C++
Result: Accepted
Time:412 ms
Memory:1664 kb
****************************************************************/ //BZOJ 3930
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define pb push_back
using namespace std;
typedef long long LL;
inline int getint(){
int r=,v=; char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if (ch=='-') r=-;
for(; isdigit(ch);ch=getchar()) v=v*-''+ch;
return r*v;
}
const int N=1e5+,P=1e9+;
/*******************template********************/ int d[N],n,K,l,r,a,b;
int Pow(int a,int b){
int r=;
for(;b;b>>=,a=(LL)a*a%P) if (b&) r=(LL)r*a%P;
return r;
}
int main(){
#ifndef ONLINE_JUDGE
freopen("3930.in","r",stdin);
freopen("3930.out","w",stdout);
#endif
n=getint(); K=getint(); a=getint(); b=getint();
l=a/K; r=b/K;
if (a%K) l++;
D(i,,){
int R=r/i,L=l/i;
if (l%i) L++;
if (l<=r){
d[i]=Pow(R-L+,n);
d[i]=(d[i]-(R-L+)+P)%P;
for(int j=i+i;j<=;j+=i) d[i]=(d[i]-d[j]+P)%P;
}
}
if (l==) d[]=(d[]+)%P;
printf("%d\n",d[]);
return ;
}

3930: [CQOI2015]选数

Time Limit: 10 Sec  Memory Limit: 512 MB
Submit: 434  Solved: 222
[Submit][Status][Discuss]

Description


们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案。小z很好奇这样选出的数的最大公约数的规律,他决定对每种方
案选出的N个整数都求一次最大公约数,以便进一步研究。然而他很快发现工作量太大了,于是向你寻求帮助。你的任务很简单,小z会告诉你一个整数K,你需要
回答他最大公约数刚好为K的选取方案有多少个。由于方案数较大,你只需要输出其除以1000000007的余数即可。

Input

输入一行,包含4个空格分开的正整数,依次为N,K,L和H。

Output

输出一个整数,为所求方案数。

Sample Input

2 2 2 4

Sample Output

3

HINT

样例解释

所有可能的选择方案:(2, 2), (2, 3), (2, 4), (3, 2), (3, 3), (3, 4), (4, 2), (4, 3), (4, 4)
其中最大公约数等于2的只有3组:(2, 2), (2, 4), (4, 2)
对于100%的数据,1≤N,K≤10^9,1≤L≤H≤10^9,H-L≤10^5

Source

[Submit][Status][Discuss]

【BZOJ】【3930】【CQOI2015】选数的更多相关文章

  1. BZOJ 3930: [CQOI2015]选数 递推

    3930: [CQOI2015]选数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pro ...

  2. 【刷题】BZOJ 3930 [CQOI2015]选数

    Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公 ...

  3. bzoj 3930: [CQOI2015]选数

    Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公 ...

  4. BZOJ 3930: [CQOI2015]选数 莫比乌斯反演

    https://www.lydsy.com/JudgeOnline/problem.php?id=3930 https://blog.csdn.net/ws_yzy/article/details/5 ...

  5. 【递推】BZOJ 3930: [CQOI2015]选数

    Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公 ...

  6. bzoj 3930: [CQOI2015]选数【快速幂+容斥】

    参考:https://www.cnblogs.com/iwtwiioi/p/4986316.html 注意区间长度为1e5级别. 则假设n个数不全相同,那么他们的gcd小于最大数-最小数,证明:则gc ...

  7. bzoj 3930: [CQOI2015]选数【递推】

    妙啊 这个题一上来就想的是莫比乌斯反演: \[ f(d)=\sum_{k=1}^{\left \lceil \frac{r}{d} \right \rceil}\mu(k)(\left \lceil ...

  8. BZOJ 3930: [CQOI2015]选数 莫比乌斯反演 + 杜教筛

    求 $\sum_{i=L}^{R}\sum_{i'=L}^{R}....[gcd_{i=1}^{n}(i)==k]$   $\Rightarrow \sum_{i=\frac{L}{k}}^{\fra ...

  9. 【BZOJ】3930: [CQOI2015]选数

    题意 从区间\([L, R]\)选\(N\)个数(可以重复),问这\(N\)个数的最大公约数是\(K\)的方案数.(\(1 \le N, K \le 10^9, 1 \le L \le R \le 1 ...

  10. 3930: [CQOI2015]选数

    Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1958  Solved: 979[Submit][Status][Discuss] Descripti ...

随机推荐

  1. String、Date和Timestamp的互转

    begin 2018年8月17日19:09:49 String.Date和Timestamp的互转 String和Date的互转 关于String和Date的互转,在java8后会有不同.因为java ...

  2. 命令行fuck神器

     文章 thefuck  git thefuck

  3. 利用transform的bug使fixed相对于父级定位

    首先,大家都清楚,元素使用fixed之后,若不设置top与left则会相对于最近的使用定位的父元素,并位于父元素的原点位置设置top与left值时,则会相对于窗口定位.但无论如何,此时仍相对于窗口定位 ...

  4. ScrollView中嵌套GridView,Listview的办法

    按照android的标准,ScrollView中是不能嵌套具有滑动特性的View的,但是有时如果设计真的有这样做的需要,或者为了更方便简单的实现外观(比如在外在的大布局需要有滑动的特性,并且内部有类似 ...

  5. 【BZOJ-2888】资源运输 LCT + 启发式合并

    2888: 资源运输 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 63  Solved: 33[Submit][Status][Discuss] D ...

  6. Ural 2037. Richness of binary words 打表找规律 构造

    2037. Richness of binary words 题目连接: http://acm.timus.ru/problem.aspx?space=1&num=2037 Descripti ...

  7. Codeforces Round #517 (Div. 2, based on Technocup 2019 Elimination Round 2)

    Codeforces Round #517 (Div. 2, based on Technocup 2019 Elimination Round 2) #include <bits/stdc++ ...

  8. 慢查询日志分析工具之mysqldumpslow

    使用方法: 在 windows 下可以在mysql/bin目录下可以找到 mysqldumpslow.pl 文件,是一个 perl 格式的文件,如下图: 这种格式的文件在windows下是不能直接执行 ...

  9. C#快速找出磁盘内的所有文件

    本文只针对NTFS格式化的磁盘文件快速检索,速度不是非常快,是让你震惊. 一般用文件遍历的方法检索一个50G的文件夹需要几十分钟甚至一个小时的时间,而用本方法只需几秒. using System; u ...

  10. 任务调度框架FluentScheduler简介

    之前我在文章中介绍过.net中的任务调度框架Hangfire,HangFire虽然本身输入比较简单好用的,但是,如果我们的程序本身提供的服务不是任务调度,而任务调度只是里面并不重要的小功能的时候,用H ...