牛客寒假训练营2-C算概率
思路
用 f(i,j) 来表示当前做了i道题,共做对了j道题
状态 f[i][j] = f[i-1][j] * (1-p[i]) + f[i-1][j-1] * p[i]
第一种:由于i-1时对了j题,所以第i题做错了;
第二种:由于i-1时对了j-1题,所以第i题对了;
时间复杂度O(n^2)
CODE
- #include <bits/stdc++.h>
- #define dbg(x) cout << #x << "=" << x << endl
- using namespace std;
- typedef long long LL;
- template<class T>inline void read(T &res)
- {
- char c;T flag=;
- while((c=getchar())<''||c>'')if(c=='-')flag=-;res=c-'';
- while((c=getchar())>=''&&c<='')res=res*+c-'';res*=flag;
- }
- namespace _buff {
- const size_t BUFF = << ;
- char ibuf[BUFF], *ib = ibuf, *ie = ibuf;
- char getc() {
- if (ib == ie) {
- ib = ibuf;
- ie = ibuf + fread(ibuf, , BUFF, stdin);
- }
- return ib == ie ? - : *ib++;
- }
- }
- int qread() {
- using namespace _buff;
- int ret = ;
- bool pos = true;
- char c = getc();
- for (; (c < '' || c > '') && c != '-'; c = getc()) {
- assert(~c);
- }
- if (c == '-') {
- pos = false;
- c = getc();
- }
- for (; c >= '' && c <= ''; c = getc()) {
- ret = (ret << ) + (ret << ) + (c ^ );
- }
- return pos ? ret : -ret;
- }
- const int kmaxn = ;
- LL f[kmaxn][kmaxn];
- const LL mod = 1e9 + ;
- int n;
- LL p[kmaxn];
- int main()
- {
- scanf("%d",&n);
- for(int i = ; i <= n; ++i) {
- scanf("%lld",&p[i]);
- }
- f[][] = ;
- for(int i = ; i <= n; ++i) {
- f[i][] = f[i-][] * (mod+-p[i]) % mod;
- for(int j = ; j <= n; ++j) {
- f[i][j] = ((f[i-][j]*(i-p[i]+mod)) % mod + f[i-][j-]*(mod+p[i]) % mod)% mod;
- }
- }
- for(int i = ; i < n; ++i) {
- printf("%lld ",f[n][i]);
- }
- printf("%lld\n",f[n][n]);
- return ;
- }
牛客寒假训练营2-C算概率的更多相关文章
- 牛客寒假训练营3 B 处女座的比赛资格(拓扑排序+最短路)
题目链接 这个题,一眼看上去就是最短路的题,边权有负环显然不能用dij,然后出题人又卡了spfa,,那怎么办的想点办法啊,好像还有一个拓扑排序可以求最短路吧,这时候正解就已经得到了,就是拓扑排序求最短 ...
- 牛客寒假训练营2-H施魔法
思路 dp去维护前缀f[i-1] - ai的最小值 CODE #include <bits/stdc++.h> #define dbg(x) cout << #x <&l ...
- honoka和格点三角形(牛客寒假训练营day1)
可以把面积为1的好三角形分成两类分开统计:两条边和两个坐标轴平行:只有一条边和某个坐标轴平行. 对于第一种情况,一定是1*2或者2*1的形式,一个1*2的矩形中含有4个不同的三角形.总数是4*((n- ...
- 2020牛客寒假算法基础集训营2 J题可以回顾回顾
2020牛客寒假算法基础集训营2 A.做游戏 这是个签到题. #include <cstdio> #include <cstdlib> #include <cstring ...
- 2020牛客寒假算法基础集训营1 J题可以回顾回顾
2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...
- 牛客寒假算法基础集训营4 F Applese 的大奖
链接:https://ac.nowcoder.com/acm/contest/330/H来源:牛客网 Applese 和它的小伙伴参加了一个促销的抽奖活动,活动的规则如下:有一个随机数生成器,能等概率 ...
- 欧拉函数-gcd-快速幂(牛客寒假算法基础集训营1-D-小a与黄金街道)
题目描述: 链接:https://ac.nowcoder.com/acm/contest/317/D来源:牛客网小a和小b来到了一条布满了黄金的街道上.它们想要带几块黄金回去,然而这里的城管担心他们拿 ...
- Applese 的毒气炸弹 G 牛客寒假算法基础集训营4(图论+最小生成树)
链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 Applese 的毒气炸弹 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262 ...
- 牛客寒假算法基础集训营3处女座和小姐姐(三) (数位dp)
链接:https://ac.nowcoder.com/acm/contest/329/G来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
随机推荐
- 在yum安装lamp的环境下安装coreseek以及php的sphinx扩展
首先说明下,之前的lamp环境用yum快速安装的现在装一个coreseek学习学习: 在安装前建议安装下这四个东西,以免后续安装报错 $ curl -O -L http://mirrors.kerne ...
- Linux文本三剑客
grep 文本过滤工具. 作用: 文本搜索工具,根据用户指定的行进行匹配检查,打印匹配到的行. 模式: 由正则表达式字符及文本字符所编写的过滤条件. grep的使用 语法: grep [OPTION ...
- 标准 I/O 和管道
1.标准输入和输出1>程序:指令+数据(指令服务于数据) 读入数据:input 输出数据:output 2>三种 I/O 设备 Linux 给程序提供三种 I/O 设备 标准输入(STDI ...
- 学习分享--python网络爬虫(一)关于如何更新python pip以及如何安装python requests库
一.python pip的更新(我的是window10 界面可能不太一样) 1.找到电脑左下角开始按钮,并点击: 2.输入cmd 3.打开以后,先查看自己的pip版本 输入:pip -V 敲回 ...
- Sublime text3的安装以及python开发环境的搭建
作者:struct_mooc 博客地址:https://www.cnblogs.com/structmooc/p/12376601.html 一. Sublime text3的安装 1.sublime ...
- .net core 部署到IIS 后出现 w3wp.exe 【】发生了未经处理的win32异常……
抗疫时期,想到弄个微信程序用于社区出入和复工复产人员流动登记,老早就买的盛派的书和视频,一直没时间看,趁这个需求,下载盛派weixinDSK开始学习,先是打开盛派的网站陆续无法打开, 帮助文档也没能抢 ...
- Spark之RDD本质
1.在一个完整的数据转换流程里往往涉及到多个具有衍生关系RDD,这些RDD其实是通过逻辑串联来利用装饰器模式层层包装扩展的的一堆对象,这些相邻RDD间必须有继承关系.并且比Java中的装饰器来的更彻底 ...
- 浏览器中常见的html语义化标签
html标签默认在浏览器中展示的样式,html标签的用途:语义化(明白每个标签的用途,在什么情况下使用此标签合理);标签语义化好处:1.更容易被搜索引擎收录2.更容易让屏幕阅读器读出网页内容. 网页上 ...
- 泡泡后台Couchbase缓存使用经验分享
一.导读 爱奇艺的社交业务“泡泡”,拥有日活用户6千万+,后台系统每日高峰期间接口QPS可以达到80K+,与视频业务的主要区别是泡泡业务更多地引入了与用户互动相关的数据,读.写的量均很大.无论是庞大的 ...
- redis的基础知识
select切换数据库 remoteSelf:0>select 0 "OK" dbsize查看当前数据库的key数量 remoteSelf:0>dbsize " ...