CF1139D Steps to One(DP,莫比乌斯反演,质因数分解)
stm这是div2的D题……我要对不住我这个紫名了……
题目大意:有个一开始为空的序列。每次操作会往序列最后加一个 $1$ 到 $m$ 的随机整数。当整个序列的 $\gcd$ 为 $1$ 时停止。问这个序列的期望长度对 $10^9+7$ 取模的值。
$1\le m\le 10^5$。
首先很容易想到DP:$f_i$ 表示目前的 $\gcd$ 为 $i$,期望还要多少次才能结束。
那么有 $f_1=0$。
转移,直接枚举即可:$f_i=1+\dfrac{1}{m}\sum\limits^m_{j=1}f_{\gcd(i,j)}$。
如果出现 $\gcd(i,j)=i$(也就是 $i|j$),那么把这种情况特殊判断,那么解个方程可以得到:
$$f_i=\dfrac{1+\dfrac{1}{m}\sum\limits^m_{j=1,i\nmid j}f_{\gcd(i,j)}}{1-\lfloor\frac{m}{i}\rfloor}$$
答案为 $\dfrac{1}{m}\sum\limits^m_{i=1}(f_i+1)$。
这是 $O(m^2\log m)$ 的。我当时就是在这里卡住了,现在感觉自己是个zz……
我们套路地枚举 $\gcd$,设 $c(i,j)$ 表示有多少个 $1\le x\le m$ 满足 $\gcd(i,x)=j$。那么就有:
$$f_i=\dfrac{1+\dfrac{1}{m}\sum\limits_{j|i}f_{j}c(i,j)}{1-\lfloor\frac{m}{i}\rfloor}$$
接下来就要考虑求 $c(i,j)(j|i)$。
$$c(i,j)=\sum\limits^m_{x=1}[\gcd(i,x)=j]$$
$$c(i,j)=\sum\limits^m_{j|x}[\gcd(\frac{i}{j},\frac{x}{j})=1]$$
$$c(i,j)=\sum\limits^{\lfloor\frac{m}{j}\rfloor}_{x=1}[\gcd(\frac{i}{j},x)=1]$$
接下来有两条路可走:分解质因数(官方做法)和莫比乌斯反演(大众做法)。
那我们先来看看大众做法。
莫比乌斯反演:
$$c(i,j)=\sum\limits^{\lfloor\frac{m}{j}\rfloor}_{x=1}\sum\limits_{d|\gcd(\frac{i}{j},x)}\mu(d)$$
$$c(i,j)=\sum\limits_{d|\frac{i}{j}}\mu(d)\sum\limits^{\lfloor\frac{m}{j}\rfloor}_{d|x}1$$
$$c(i,j)=\sum\limits_{d|\frac{i}{j}}\mu(d)\lfloor\dfrac{m}{jd}\rfloor$$
此时求 $c(i,j)$ 复杂度为 $O(\sqrt{\frac{i}{j}})$。
总复杂度为 $O(\sum\limits^m_{i=2}\sum\limits_{j|i}\sqrt{\frac{i}{j}})=O(\sum\limits^m_{i=2}\sum\limits_{j|i}\sqrt{j})=O(\sum\limits^m_{j=1}\sqrt{j}\lfloor\frac{m}{j}\rfloor)\approx O(m\int^m_1j^{-\frac{1}{2}}\mathrm{d}j)=O(m\sqrt{m})$。
分解质因数:
我们不妨修改一下定义(只是为了方便):令 $c(x,y)=\sum\limits^y_{i=1}[\gcd(i,x)=1]$。那么原来的 $c(i,j)$ 就变成了现在的 $c(\frac{i}{j},\lfloor\frac{m}{j}\rfloor)$。
也就是要 $i$ 和 $x$ 的质因子集合没有交集。
我们从反向考虑,考虑与 $x$ 的质因子有交集的 $i$ 的个数。
先对 $x$ 质因数分解,设分解出的不同质因子有 $p_1,p_2\cdots p_k$。那么有 $k\le 6$。
那么与集合 $S$ 有交的 $i$ 的个数就是 $\lfloor\frac{y}{\prod S_i}\rfloor$。
然后还要再容斥一下。那么总的就是:
$$c(x,y)=y-\sum\limits_{S\in x_{pr},S\ne\varnothing}(-1)^{|S|+1}\lfloor\frac{y}{\prod S_i}\rfloor$$
当然也可以写成:(这是代码中的写法)
$$c(x,y)=\sum\limits_{S\in x_{pr}}(-1)^{|S|}\lfloor\frac{y}{\prod S_i}\rfloor$$
此时转移方程为:
$$f_i=\dfrac{1+\dfrac{1}{m}\sum\limits_{j|i}f_{j}c(\frac{i}{j},\lfloor\frac{m}{j}\rfloor)}{1-\lfloor\frac{m}{i}\rfloor}$$
这个可以做到 $O(2^k+\sqrt{x})$。注意最好用DFS,不要用二进制枚举,否则会退化为 $O(2^k\times k+\sqrt{x})$。(虽然也能过)
时间复杂度也是 $O(m\sqrt{m})$。
由于大多数人写的都是莫比乌斯反演,我就写一发质因数分解给大家。
#include<bits/stdc++.h>
using namespace std;
const int maxn=,mod=;
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
inline int read(){
char ch=getchar();int x=,f=;
while(ch<'' || ch>'') f|=ch=='-',ch=getchar();
while(ch>='' && ch<='') x=x*+ch-'',ch=getchar();
return f?-x:x;
}
int m,f[maxn],fac[],fl;
inline int qpow(int a,int b){
int ans=;
for(;b;b>>=,a=1ll*a*a%mod) if(b&) ans=1ll*ans*a%mod;
return ans;
}
int dfs(int dep,int pro,int sgn,int up){ //dep表示正在枚举第几个质因子,pro表示S的乘积,sgn表示容斥系数(1或-1),up表示上界
if(dep>fl) return up/pro*sgn;
else return dfs(dep+,pro,sgn,up)+dfs(dep+,pro*fac[dep],-sgn,up);
}
int cnt(int x,int y){
fl=;
for(int i=;i*i<=x;i++)
if(x%i==){
fac[++fl]=i;
while(x%i==) x/=i;
}
if(x>) fac[++fl]=x;
return dfs(,,,y);
}
int main(){
m=read();int inv=qpow(m,mod-);
f[]=;
FOR(i,,m){
if(i!=){ //最后要除以m,加1再除以1-m/i
f[i]=1ll*f[i]*inv%mod;
f[i]=(f[i]+)%mod;
f[i]=1ll*f[i]*qpow((-1ll*(m/i)*inv%mod+mod)%mod,mod-)%mod;
}
FOR(j,,m/i) f[i*j]=(f[i*j]+1ll*f[i]*cnt(j,m/i))%mod;
//枚举i的倍数,f[i*j]+=f[i]*c((i*j)/i,m/i)
}
int ans=;
FOR(i,,m) ans=(ans+f[i]+)%mod; //累加答案
ans=1ll*ans*inv%mod;
printf("%d\n",ans);
}
CF1139D Steps to One(DP,莫比乌斯反演,质因数分解)的更多相关文章
- CF1139D Steps to One (莫比乌斯反演 期望dp)
\[ f[1] = 0 \] \[ f[i] = 1 + \frac{1}{m} \sum_{j = 1} ^ n f[gcd(i, j)] \ \ \ \ \ \ (i != 1) \] 然后发现后 ...
- Codeforces.1139D.Steps to One(DP 莫比乌斯反演)
题目链接 啊啊啊我在干什么啊.怎么这么颓一道题做这么久.. 又记错莫比乌斯反演式子了(╯‵□′)╯︵┻━┻ \(Description\) 给定\(n\).有一个初始为空的集合\(S\).令\(g\) ...
- Steps to One DP+莫比乌斯反演
卧槽,这么秀吗??? 暂时留坑...
- T^TOJ - 2360 - Home_W的超级数学题 - 莫比乌斯反演 - 质因数分解
求单个莫比乌斯函数忘记算n本身的质数,WA了一发. http://www.fjutacm.com/Problem.jsp?pid=2360 首先,显然随着n增大,与m互质的数不会变少.可以二分来求k, ...
- Codeforces - 1139D - Steps to One (概率DP+莫比乌斯反演)
蒟蒻数学渣呀,根本不会做. 解法是参考 https://blog.csdn.net/xs18952904/article/details/88785210 这位大佬的. 状态的设计和转移如上面博客一样 ...
- codeforces#1139D. Steps to One (概率dp+莫比乌斯反演)
题目链接: http://codeforces.com/contest/1139/problem/D 题意: 在$1$到$m$中选择一个数,加入到一个初始为空的序列中,当序列的$gcd$和为$1$时, ...
- cf1139D. Steps to One(dp)
题意 题目链接 从\([1, M]\)中随机选数,问使得所有数gcd=1的期望步数 Sol 一个很显然的思路是设\(f[i]\)表示当前数为\(i\),期望的操作轮数,转移的时候直接枚举gcd \(f ...
- Codeforces Round #548 (Div. 2) D 期望dp + 莫比乌斯反演
https://codeforces.com/contest/1139/problem/D 题意 每次从1,m中选一个数加入队列,假如队列的gcd==1停止,问队列长度的期望 题解 概率正着推,期望反 ...
- 【期望dp 质因数分解】cf1139D. Steps to One
有一种组合方向的考虑有没有dalao肯高抬啊? 题目大意 有一个初始为空的数组$a$,按照以下的流程进行操作: 在$1\cdots m$中等概率选出一个数$x$并添加到$a$的末尾 如果$a$中所有元 ...
随机推荐
- 获取环境变量,0x000000cb 操作系统找不到已输入的环境选项
include "stdafx.h" #include <Windows.h> #include <iostream> #pragma warning(di ...
- Quartz框架学习(1)—核心层次结构
Quartz框架学习 Quartz(任务调度)框架的核心组件: job:任务.即任务调度行为中所要调度的对象. trigger:触发器.是什么促使了一个任务的调度?当然是时间.这也算事件驱动类型程序. ...
- js中this指向、箭头函数
普通函数:this指向分为4种情况,1. obj.getName();//指向obj2.getName();//非严格模式下,指向window,严格模式下为undefined3. var a = ne ...
- Window下通过SecureCRT的SSH2跳转到另一台Linux服务器
我工作中的示例: 先登录192.168.2.145 Your password will be expired in 200 days.Welcome to Baoleiji System.Last ...
- python之路--递归, 二分法
一 . 递归 自己调用自己, 递归的入口(参数) 和 出口(return), 树形结构的遍历. def func(): print("我是递归") func() func() ...
- spring boot session error
Error starting ApplicationContext. To display the conditions report re-run your application with 'de ...
- 莫烦theano学习自修第三天【共享变量】
1. 代码实现 #!/usr/bin/env python #! _*_ coding:UTF-8 _*_ import numpy as np import theano.tensor as T i ...
- Lodop打印控件不打印css背景图怎么办
background:url()这是css背景图,http协议会按异步方式下载背景图,所以很容易等不到下载完毕就开始打印了,故lodop不打印css背景图.Lodop不打印css背景图,但是有其他方法 ...
- Redis宕机的问题
在主从模式下宕机要分为区分来看: slave从redis宕机 在Redis中从库重新启动后会自动加入到主从架构中,自动完成同步数据: 如果从数据库实现了持久化,只要重新假如到主从架构中会实现增 ...
- VMware ezmomi工具使用
用两个静态IP克隆模板: ezmomi clone --template centos67 --hostname test01 --cpus 2 --mem 4 --ips 172.10.16.203 ...