当前位置: 首页 > news >正文

网站后台管理系统内容图片链接生成器软件

网站后台管理系统内容,图片链接生成器软件,企业软件网站建设,网站建设的调研报告URL:https://atcoder.jp/contests/abc295 目录 E Problem/题意 Thought/思路 Code/代码 E Problem/题意 给定长度为 N 的数组 A。进行如下操作: 若 Ai 0,将 Ai 等概率地变为 1 ~ M 中的任意一个数;对 A 排序; …

URL:https://atcoder.jp/contests/abc295

目录

E

Problem/题意

Thought/思路

Code/代码


E

Problem/题意

给定长度为 N 的数组 A。进行如下操作:

  • 若 Ai = 0,将 Ai 等概率地变为 1 ~ M 中的任意一个数;
  • 对 A 排序;

问第 K 个数地期望是多少。

Thought/思路

概率 DP。(一开始想不明白这个公式,概率论白雪了)

设我们要求的 A[k] = x 且 P[i] 为 x = i 的概率,那么就有如下公式:

E(x) = \sum_{i=1}^{m}i*P(i=x)=\sum_{i=1}^{m}P(x \geqslant i)

 关于这条公式地推导:https://zhuanlan.zhihu.com/p/617048570

因此接下来的问题就变成了:对于每个 i,求出 P(A[k] >= i)。


但是我们不知道 A[k] 该怎么取值,所以还需要将 P(A[k] >= i) 转换为:后面 N - K + 1 个数 >= i 的概率,也就是 [K, N] 中的数都 >= i 的概率。(假设已经排好序)

显然 [K, N] 中的数不会都 >= i,而一般的情况就是:[K, N] 中的前一部分的数 < i、后一部分的数 >= i。


对于前一部分,我们需要依靠 0 来变成 >= i 的数去替换他们,所以记录前一部分的数的个数为 need,这代表了所需要的 0 的最少数量。

也就是说,如果 0 的数量(设为 zero)zero < need,那么就永远不可能满足 [K, N] 中的数都 >= i,概率为 0;反之,如果 need <= 0,就一定满足 [K, N] 中的数都 >= i,概率为 1;


基于概率为 0 的那种情况,就一定能保证 need <= zero。

而 need 是需要的 0 的最少数量,那么我们就可以设:有 need 个 0 变成了 >= i 的数,其带来的概率为:

p(need) = C_{zero}^{need} * P^{need} * (1 - P)^{zero-need}

 其中 P = (m - i + 1) / m,意思是:取出 >= i 的数的概率。

显然一共有 zero 个 0 可以使用,所以考虑 [need, zero] 每一种情况即可。

Code/代码

#include "bits/stdc++.h"#define int long longconst int mod = 998244353;int n, m, k, a[2007], fact[2007], invf[2007];int ksm(int a, int b) {int res = 1;while (b > 0) {if (b & 1) res = res * a % mod;a = a * a % mod;b /= 2;}return res;
}void init() {fact[0] = 1, invf[0] = ksm(1, mod - 2);for (int i = 1; i <= 2000; ++ i) {fact[i] = fact[i - 1] * i % mod;invf[i] = ksm(fact[i], mod - 2) % mod;}
}int C(int x, int y) {if (x < y) return 0;return fact[x] * invf[y] % mod * invf[x - y] % mod;
}signed main() {std::cin >> n >> m >> k;for (int i = 1; i <= n; ++ i) std::cin >> a[i];init();int ans = 0;for (int i = 1; i <= m; ++ i) {int zero = 0, need = n - k + 1;for (int j = 1; j <= n; ++ j) {if (a[j] >= i) need --;if (a[j] == 0) zero ++;}if (need <= 0 or need > zero) { // [k, n] 都 >= i,概率为 1;[k, n] 小于 i 的个数,0 补不上,概率为 0。ans = (ans + (need <= 0 ? 1 : 0)) % mod;continue;}int p1 = (m - i + 1) * ksm(m, mod - 2) % mod; // 选出的数 >= i 的概率 p:(m - i + 1) / mint p2 = (i - 1) * ksm(m, mod - 2) % mod; // 1 - p:(i - 1) / mstd::vector <int> dp1(zero + 1), dp2(zero + 1);dp1[0] = dp2[0] = ksm(1, mod - 2);for (int j = 1; j <= zero; ++ j) {dp1[j] = dp1[j - 1] * p1 % mod;dp2[j] = dp2[j - 1] * p2 % mod;}// 用 0 补充 >= i 的数for (int j = need; j <= zero; ++ j) {ans = (ans + C(zero, j) * dp1[j] % mod * dp2[zero - j] % mod) % mod;}}std::cout << ans;return 0;
}
http://www.yayakq.cn/news/783618/

相关文章:

  • 如何建网站看到物联网设备信息百度做广告费用
  • 山东淄博网站建设公司洛阳有哪些做网站的公司
  • 网站推广seo招聘重庆网站制作公司重庆
  • 被墙网站怎么做301跳转北京广告设计公司排名前十强
  • 网站建设公司河南推荐做问卷的网站
  • 深圳工信部网站免费网站设计软件
  • 如何在公司系统建网站wordpress元关键词
  • 娄底建设企业网站wordpress信息搜集
  • 亳州市网站建设公司西安seo管理
  • 沈阳德泰诺网站制作懒人手机网站模板
  • 海口网站建设发布北京低价做网站
  • 微信网站开发rem px长春 行业网站
  • 泉州专业网站建设网站建设七大步骤
  • 品牌网站建设有哪些功能海珠建网站的公司
  • 企业建筑网站网页美工设计ppt
  • 网站如何增加增删查改怎么做深圳建立网站公司网站
  • 百度网站排名规则互联网营销成功案例
  • 医药网站前置审批临清网站建设临清
  • 汕头网站建设公司天津平台网站建设公司
  • 长沙工程建设管理中心网站广州市住房与城乡建设厅网站
  • 温州外贸网站制作网站建设 创业
  • 沈阳网站建设的价格怎么把网址做成网页链接
  • 网站建设的步骤过程ppt淄博网站建设公司哪家好
  • 葫芦岛公司做网站电商网站建设哪家公司好
  • 北京迈程网络网站建设公司如何自己建网站服务器
  • 开一家网络公司做网站前景如何高端的扬中网站建设
  • 自己做网站要多少钱大连建设网水电费查询官网
  • 淘宝客怎么在网站做推广网站建设代码介绍
  • 南沙区交通和建设局网站婚纱网站设计首页
  • 学前端要逛那些网站门户型网站建设方案