D. Steps to One
题意
初始有一个空数组\(a\),接下来每次操作会这么做:
- 在\([1,n]\)中选择一个数,将其拼接在数组\(a\)后。
- 计算数组\(a\)的\(\gcd\)。
- 如果结果是\(1\),退出。
- 否则,回到步骤1.
试问数组\(a\)长度的期望,答案对\(1e^9+7\)取模。
题解
莫反解法
考虑dp。
设\(dp[x]\)为当前数组的\(\gcd\)为\(x\)时的期望长度,那么答案便是
\]
由\(dp[x]\)的意义,考虑对其因子进行转移,即
\]
然而\(O(n^2)\)的时间复杂度必定是超时的,于是考虑优化。
对于\(\gcd(i,x)\),它必定是\(x\)的因子,于是可以优化成
\]
其中\(h(x,d)\)表示\([1,n]\)中与\(x\)的\(\gcd\)为\(d\)的个数,即
\]
对于优化后的\(dp[x]\)的表达式,由于左右两边可能都含有\(dp[x]\),于是我们把\(dp[x]\)单独分离出来
\]
其中
\]
通过移项,变形得
\]
接下来再分析\(h(x,d)\):
\]
变换求和顺序得
\]
带入原式
\]
AC代码
#include <bits/stdc++.h>
#define IO ios::sync_with_stdio(NULL)
#define sc(z) scanf("%d", &(z))
#define _ff(i, a, b) for (ll i = a; i <= b; ++i)
#define _rr(i, a, b) for (ll i = b; i >= a; --i)
#define _f(i, a, b) for (ll i = a; i < b; ++i)
#define _r(i, a, b) for (ll i = b - 1; i >= a; --i)
#define pii pair<int, int>
#define mkp make_pair
#define endl "\n"
using namespace std;
typedef long long ll;
const int N = 1e6 + 5;
const ll mod = 1e9 + 7;
ll dp[N];
vector<ll> mind[N];
bool prime[N];
ll primes[N], cnt, mu[N], inv[N];
void precompute() {
mu[1] = 1, cnt = 0;
_ff(i, 2, N) {
if (!prime[i]) {
primes[cnt++] = i;
mu[i] = -1;
}
_f(j, 0, cnt) {
if (primes[j] * i > N) break;
prime[i * primes[j]] = 1;
if (i % primes[j]) {
mu[i * primes[j]] = -mu[i];
} else {
mu[i * primes[j]] = 0;
break;
}
}
}
_ff(i, 1, N) {
mu[i] = (mu[i] + mod) % mod;
for (int j = i + i; j < N; j += i) mind[j].push_back(i);
}
inv[1] = 1;
_ff(i, 2, N) inv[i] = (mod - mod / i) * inv[mod % i] % mod;
}
int main() {
ll n; cin >> n;
precompute();
_ff(x, 2, n) {
dp[x] = n;
for (ll d : mind[x]) {
//由于之前筛因子的时候并没有把自身筛进去,于是这里要单独计算t=x/d的情况
ll s = n / x * mu[x / d] % mod;
for (ll t : mind[x / d]) {
s = (s + n / d / t * mu[t]) % mod;
}
dp[x] = (dp[x] + s * dp[d]) % mod;
}
dp[x] = dp[x] * inv[n - n / x] % mod;
}
ll ans = 0;
_ff(i, 1, n) ans = (ans + dp[i]) % mod;
ans = ans * inv[n] % mod;
cout << ans + 1 % mod;
return 0;
}
无穷级数解法
根据期望的定义,我们可以得到
\]
如何计算\(P(i)\)呢?我们设\(P(E)\)为事件\(E\)发生的概率,设当前长度为\(len\),那么我们可以计算\(len\)的期望\(P(len>x)\):
\]
注意到\(len>x\)就意味着所有前\(x\)个数是不互质的,那么\(P(len>x)\)就可以表示为
\]
我们令\(ans_i=\sum_{x=1}^{\infty}P(\gcd(a_1,a_2,...,a_x)=i)\),那么最终答案就为
\]
那么如何计算\(ans_i\)呢?我们可以根据容斥原理,先计算前\(x\)个数都是x的倍数的概率,再减去前\(x\)个数的\(\gcd\)是\(i\)的倍数的概率,即
\]
我们很容易知道,在\([1,n]\)中取一个\(i\)的倍数的概率为\(\frac{\lfloor \frac{n}{i}\rfloor}{n}\),那么原式就为
\]
很容易知道,级数\(\sum_{x=1}^{\infty}(\frac{\lfloor \frac{n}{i}\rfloor}{n})^x\)是收敛的,收敛为\(\frac{1}{1-\frac{\lfloor \frac{n}{i}\rfloor}{n}}-1\)。
AC代码
#include <bits/stdc++.h>
#define IO ios::sync_with_stdio(NULL)
#define sc(z) scanf("%d", &(z))
#define _ff(i, a, b) for (int i = a; i <= b; ++i)
#define _rr(i, a, b) for (int i = b; i >= a; --i)
#define _f(i, a, b) for (int i = a; i < b; ++i)
#define _r(i, a, b) for (int i = b - 1; i >= a; --i)
#define pii pair<int, int>
#define mp make_pair
using namespace std;
typedef long long ll;
const int N = 1e5 + 5;
const ll mod = 1e9 + 7;
ll ans[N];
ll qpow(ll a, ll b) {
ll res = 1;
while (b) {
if (b & 1) res = (res * a) % mod;
a = (a * a) % mod;
b >>= 1;
}
return res;
}
ll inv(ll x) { return qpow(x, mod - 2); }
int main() {
ll n; cin >> n;
ll dans = 1;
_rr(i, 2, n) {
ans[i] = (inv((1 - n / i * inv(n) + mod) % mod) - 1 + mod) % mod;
for (ll j = i + i; j <= n; j += i) {
ans[i] = (ans[i] - ans[j] + mod) % mod;
}
dans = (dans + ans[i]) % mod;
}
cout << dans;
return 0;
}
D. Steps to One的更多相关文章
- animation-timing-function: steps() 详解
在应用 CSS3 渐变/动画时,有个控制时间的属性 <animation-timing-function> .它的取值中除了常用到的 贝萨尔曲线以外,还有个让人比较困惑的 steps() ...
- CSS3 Animation 帧动画 steps()
@keyframes fn{ 0%{} 100%{} } CSS3的Animation有八个属性 animation-name :动画名 fn animation-duration:时间 1s ani ...
- SAML 2.0 setup steps, 效果图
Steps of setting up SAML SSO. 效果图 # Registry a Identity Provider services in:(Might need purchase) I ...
- 【译】css动画里的steps()用法详解
原文地址:http://designmodo.com/steps-c... 原文作者:Joni Trythall 我想你在css 动画里使用steps()会和我一样有很多困惑.一开始我不清楚怎样使用它 ...
- css3动画中的steps值详解
css3的动画的animation-timing-function属性定义了动画的速度曲线,一般的速度曲线大家都知道,什么ease,linear,ease-in,ease-out,还有自定义贝塞尔曲线 ...
- steps animation
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- sdutoj 2623 The number of steps
http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2623 The number of steps ...
- SAP NWBC for HTML and Desktop configuration steps[From sdn]
Summary :- This dcoumnenst conatin the information about requirement , hardware , configuration step ...
- 【转载】7 Steps for Calculating the Largest Lyapunov Exponent of Continuous Systems
原文地址:http://sprott.physics.wisc.edu/chaos/lyapexp.htm The usual test for chaos is calculation of the ...
- BSGS算法_Baby steps giant steps算法(无扩展)详解
Baby Steps-Varsity Giant Step-Astronauts(May'n・椎名慶治) 阅读时可以听听这两首歌,加深对这个算法的理解.(Baby steps少女时代翻唱过,这个原唱反 ...
随机推荐
- Eureka服务剔除下线
1.参考文档: https://www.centoscn.vip/4317.html 2.剔除服务 格式: curl -X PUT "http://ip:port/eureka/apps/{ ...
- win10系统IE浏览器打不开 点击无反应 解决办法
打开左下角开始菜单 步骤阅读 2 点击右边的Cortana,在下面的输入框中输入:regedit,等待它自动搜索出来后,以管理员身份打开这个注册表编辑器:当然熟悉电脑的同学可以直接打开运行----re ...
- 前端之Vue day08 Vue3项目搭建、setup、toRefs
一.Vue3 介绍 # 新项目使用vue3,有部分老项目使用vue2 # vue3 的变化 1.性能的提升 -打包大小减少41% -初次渲染快55%, 更新渲染快133% -内存减少54% 2.源码的 ...
- 解决elementplus carousel固定高度问题/ResizeObserverAPI介绍
"element-plus": "^2.2.26", "@vueuse/components": "^9.7.0", 引 ...
- (0828)【vivado版本-对仿真工具版本要求】
(1)https://blog.csdn.net/Alonger1988/article/details/120506385 vivado,vsim版本兼容问题 (2)版本匹配:http://deng ...
- xss-labs
level1 <h1 align=center>欢迎来到level1</h1> <h2 align=center>欢迎用户te111</h2><c ...
- springcloud(五) - 网关gateway
功能介绍 springcloud gateway提供一种以路由的方式,基于Filter链的方式提供网关的基本功能.如安全.监控.限流. 网关:将不同协议的网络段连接到一起的设备,外网进入内网的入口,对 ...
- Qt 按键添加图标
1.开发环境:Qt5.12.2,QtCreate4.8.2 2.直接上代码 /* 按键上背景 */ QPixmap pixmap(":/Resourses/images/easyicon_n ...
- winform高dpi问题探索
winform的高dpi适应问题由来已久,属于一个历史遗留问题.主要是由于winform对不同尺寸.不同分辨率的屏幕适配不足造成的.接下来我们简单说一下如何解决,最后我们探索一下解决此问题的原理. ...
- 把pyecharts动图导入到PPT中
如何把echarts 动图导入PPT 置顶 且听风来 2019-05-22 14:54:17 3347 收藏 6展开 首先看PPT是否开启插件,开启后 此处就有标志,然后就在你想插入的幻灯片处插入两个 ...