题目链接:洛谷

作为一只沉迷数学多年的蒟蒻OIer,在推柿子和dp之间肯定要选推柿子的!

首先假设线段长度为1,最后答案乘上$l$即可。

对于$x$这个位置,被区间覆盖的概率是$2x(1-x)$(线段端点分别在$x$的两边),不被区间覆盖的概率为$1-2x(1-x)$。

$$Ans=\sum_{i=k}^n {n\choose i}\int_{0}^1(2x(1-x))^i(1-2x(1-x))^{n-i}dx$$

$$=\sum_{i=k}^n {n\choose i}\int_{0}^1(2x(1-x))^i\sum_{j=0}^{n-i}(-1)^j{n-i\choose j}(2x(1-x))^jdx$$

$$=\sum_{i=k}^n{n\choose i}\sum_{j=0}^{n-i}(-1)^j2^{i+j}{n-i\choose j}\int_0^1x^{i+j}(1-x)^{i+j}dx$$

$$F_i=\int_0^1x^i(1-x)^idx$$

$$=\int_0^1x^i\sum_{j=0}^i(-1)^j{i\choose j}x^jdx$$

$$=\sum_{j=0}^i(-1)^j{i\choose j}\int_0^1x^{i+j}dx$$

$$=\sum_{j=0}^i(-1)^j{i\choose j}\frac{1}{i+j+1}$$

预处理$F_i$之后计算,时间复杂度$O(n^2)$。

 #include<bits/stdc++.h>
#define Rint register int
using namespace std;
typedef long long LL;
const int N = , mod = ;
int fac[N], inv[N], invfac[N], po[N];
inline void init(int m){
fac[] = ;
for(Rint i = ;i <= m;i ++) fac[i] = (LL) i * fac[i - ] % mod;
inv[] = ;
for(Rint i = ;i <= m;i ++) inv[i] = (LL) (mod - mod / i) * inv[mod % i] % mod;
invfac[] = ;
for(Rint i = ;i <= m;i ++) invfac[i] = (LL) invfac[i - ] * inv[i] % mod;
po[] = ;
for(Rint i = ;i <= m;i ++) po[i] = (po[i - ] << ) % mod;
}
inline int C(int n, int m){
if(n < m || m < ) return ;
return (LL) fac[n] * invfac[n - m] % mod * invfac[m] % mod;
}
int n, k, l, ans, f[N];
int main(){
scanf("%d%d%d", &n, &k, &l);
init(n << | );
for(Rint i = k;i <= n;i ++)
for(Rint j = ;j <= i;j ++){
int t = (LL) C(i, j) * inv[i + j + ] % mod;
if(j & ) f[i] = (f[i] + mod - t) % mod; else f[i] = (f[i] + t) % mod;
}
for(Rint i = k;i <= n;i ++){
int t1 = ;
for(Rint j = ;j <= n - i;j ++){
int t2 = (LL) po[i + j] * C(n - i, j) % mod * f[i + j] % mod;
if(j & ) t1 = (t1 + mod - t2) % mod; else t1 = (t1 + t2) % mod;
}
ans = (ans + (LL) t1 * C(n, i) % mod) % mod;
}
printf("%d", (LL) l * ans % mod);
}

CF1153F

据说这个式子还可以用NTT优化到$O(n\log n)$?有兴趣的各位可以思考一下反正我是没兴趣了

upd(2019-10-18):

貌似有一个东西叫做Beta Function.

$$\begin{aligned}\Beta(x,y)&=\int_0^1t^x(1-t)^y\mathrm{d}t & (x,y\in \R_+)\\ \Gamma(z)&=\int_0^{+\infty}x^{z-1}e^{-x}\mathrm{d}x & (\Re(z)>0)\end{aligned}$$

有一些不知道为什么的结论。

$$\begin{aligned}\Gamma(n)&=(n-1)! & (n\in \N_+) \\ \Beta(x,y)&=\frac{\Gamma(x)\Gamma(y)}{\Gamma(x+y)}\end{aligned}$$

于是上面的$F_i$直接就做完了。稍微化化就可以用NTT来做了。

CF1153F Serval and Bonus Problem 【期望】的更多相关文章

  1. CF1153F Serval and Bonus Problem FFT

    CF1153F Serval and Bonus Problem 官方的解法是\(O(n ^ 2)\)的,这里给出一个\(O(n \log n)\)的做法. 首先对于长度为\(l\)的线段,显然它的答 ...

  2. CF1153F Serval and Bonus Problem

    Serval and Bonus Problem 1.转化为l=1,最后乘上l 2.对于一个方案,就是随便选择一个点,选在合法区间内的概率 3.对于本质相同的所有方案考虑在一起,贡献就是合法区间个数/ ...

  3. Codeforces 1153F Serval and Bonus Problem [积分,期望]

    Codeforces 思路 去他的DP,暴力积分多好-- 首先发现\(l\)没有用,所以不管它. 然后考虑期望的线性性,可以知道答案就是 \[ \int_0^1 \left[ \sum_{i=k}^n ...

  4. Codeforces1153F Serval and Bonus Problem 【组合数】

    题目分析: 我们思考正好被k个区间覆盖的情况,那么当前这个子段是不是把所有的点分成了两个部分,那么在两个部分之间相互连k条线,再对于剩下的分别连线就很好了?这个东西不难用组合数写出来. 然后我们要证明 ...

  5. CF1153 F. Serval and Bonus Problem(dp)

    题意 一个长为 \(l\) 的线段,每次等概率选择线段上两个点,共选出 \(n\) 条线段,求至少被 \(k\) 条线段覆盖的长度期望. 数据范围 \(1 \le k \le n \le 2000, ...

  6. Codeforces Round #551 (Div. 2) F. Serval and Bonus Problem (DP/FFT)

    yyb大佬的博客 这线段期望好神啊... 还有O(nlogn)FFTO(nlogn)FFTO(nlogn)FFT的做法 Freopen大佬的博客 本蒟蒻只会O(n2)O(n^2)O(n2) CODE ...

  7. @codeforces - 1153F@ Serval and Bonus Problem

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 从一条长度为 l 的线段中随机选择 n 条线段,共 2*n 个线 ...

  8. Codeforces Round #551 (Div. 2) EF Solution

    E. Serval and Snake 对于一个矩形,如果蛇的一条边与它相交,就意味着这条蛇从矩形内穿到矩形外,或者从矩形外穿到矩形内.所以如果某个矩形的答案为偶数,意味着蛇的头尾在矩形的同一侧(内或 ...

  9. 【Codeforces】Codeforces Round #551 (Div. 2)

    Codeforces Round #551 (Div. 2) 算是放弃颓废决定好好打比赛好好刷题的开始吧 A. Serval and Bus 处理每个巴士最早到站且大于t的时间 #include &l ...

随机推荐

  1. Codeforces 1245 D. Shichikuji and Power Grid

    传送门 经典的最小生成树模型 建一个点 $0$ ,向所有其他点 $x$ 连一条边权为 $c[x]$ 的边,其他任意两点之间连边,边权为 $(k_i+k_j)(\left | x_i-x_j\right ...

  2. PAT-1001 A+B Format (20 分) 注意零的特例

    Calculate a+b and output the sum in standard format -- that is, the digits must be separated into gr ...

  3. java多线程:继承Thread和实现Runable接口的区别

    java中我们想要实现多线程常用的有两种方法,继承Thread 类和实现Runnable 接口,有经验的程序员都会选择实现Runnable接口 ,其主要原因有以下两点: 首先,java只能单继承,因此 ...

  4. js中 this 的指向

    js中 this的指向一共存在3种地方: 1.全局的this; 2.构造函数的this; 3.call/apply; 一.全局的this: function test(){ this.d = 3;// ...

  5. nodejs连接mysql数据库,报错Client does not support authentication protocol requested by server的解决方法

    最近想要尝试nodejs连接本地数据库,往全栈方向做一个小小的尝试,于是下载了一个 MySQL8.0,发现Navicat连接不上,结果就下载了mysql自身的Workbench,继续使用. 然而,难受 ...

  6. Idea查看一个类和子类(实现类)的结构图

    选择一个类:右键选择Diagrams-show Diagrams(show Diagrams popup表示悬浮当前窗口) 进入下面类似下面的界面: 如果想查看某个类或接口的子类: 先查看自己本地设置 ...

  7. Python之定义默认参数

    定义函数的时候,还可以有默认参数. 例如Python自带的 int() 函数,其实就有两个参数,我们既可以传一个参数,又可以传两个参数: >>> int('123') 123 > ...

  8. mongodb备份每一天的数据

    需求:把mongodb里面存储6个月的数据备份到本地,一天天的来备份,方便对备份管理.然后mongo保留一周的数据(优化查询速度,可以用mongo的ttl来实现,但是我的业务场景不太适合用ttl索引) ...

  9. JAVA处理数字与中文数字互转(最大处理数字不超过万兆即:9999999999999999.9999)

    package practice; import java.util.Arrays; /** * 数字与中文数字互转(最大处理数字不超过万兆即:9999999999999999.9999) * @au ...

  10. MySQL数据库用户和权限管理

    一.视图 视图:VIEW,虚表,保存有实表的查询结果,在视图插入的内容都会存入表中.创建方法: CREATE VIEW view_name [(column_list)] AS select_st ...