https://www.lydsy.com/JudgeOnline/problem.php?id=5340

https://www.luogu.org/problemnew/show/P4564

https://loj.ac/problem/2552

(这送分题我写不出来……我退役吧)

也懒得写题解了,看https://kelin.blog.luogu.org/solution-p4564吧。

什么你说op=1的你没听懂,那你可能和我一样了(握手(大雾。

那么遵从原题解的命名,f[u][i]表示除u以外有i个人活着的概率,g[i]为i个人活着的概率,p[u]表示u活着的概率。

(其实正确的思路应该先想到g数组如何求,然后发现g数组的信息无法落到每个具体人的头上,所以需要f数组。)

则可以发现,g的范围比f大(包括了u活着的可能性),于是需要扣除u活着时候有i个人活着的概率。

所以答案就是g[i]-p[u]*f[u][i-1]了……等等我怎么样例都过不去emmm

其实!这个式子蕴含了一个信息就是保证了u是死的,而实际上我们要求的是不知道u的死活的概率,于是除以(1-p[u])就是答案了。

(然而这个思路可能考场上很难想吧……大部分人应该都是靠推推出来的这个式子,只有我啥也不会……)

#include<cmath>
#include<queue>
#include<cstdio>
#include<cctype>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=;
const int p=;
inline int read(){
int X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
inline void write(int x){
if(x>)write(x/);
putchar(x%+'');
}
int qpow(int k,int n){
int res=;
while(n){
if(n&)res=(ll)res*k%p;
k=(ll)k*k%p;n>>=;
}
return res;
}
int n,q,f[N][],g[N],h[N],s[N],inv[N];
inline int add(ll x,int y){
x+=y;if(x>=p)x-=p;return x;
}
inline int sub(int x,int y){
x-=y;if(x<)x+=p;return x;
}
int main(){
n=read();
for(int i=;i<=n;i++)f[i][read()]=;
inv[]=;
for(int i=;i<N;i++)inv[i]=(ll)(p-p/i)*inv[p%i]%p;
q=read();
while(q--){
int op=read();
if(!op){
int id=read(),u=read(),v=read();
int P=(ll)u*qpow(v,p-)%p;
f[id][]=(f[id][]+(ll)P*f[id][]%p)%p;
for(int i=;i<=;i++)
f[id][i]=add((ll)sub(,P)*f[id][i]%p,(ll)P*f[id][i+]%p);
}else{
int k=read();
for(int i=;i<=k;i++)s[i]=sub(,f[read()][]),h[i]=;
h[]=;
for(int i=;i<=k;i++)
for(int j=i;j>=;j--)
if(!j)h[j]=(ll)sub(,s[i])*h[j]%p;
else h[j]=add((ll)s[i]*h[j-]%p,(ll)(p+-s[i])*h[j]%p);
for(int i=;i<=k;i++){
if(!s[i]){putchar('');putchar(' ');continue;}
if(s[i]==)
for(int j=;j<=k-;j++)g[j]=h[j+];
else{
int Inv=qpow(sub(,s[i]),p-);g[]=(ll)h[]*Inv%p;
for(int j=;j<=k-;j++){
g[j]=(ll)sub(h[j],(ll)g[j-]*s[i]%p)*Inv%p;
}
}
int ans=;
for(int j=;j<=k-;j++)ans=add(ans,(ll)g[j]*inv[j+]%p);
write((ll)ans*s[i]%p);putchar(' ');
}
putchar('\n');
}
}
for(int i=;i<=n;i++){
int ans=;
for(int j=;j<=;j++)
(ans+=(ll)f[i][j]*j%p)%=p;
write(ans);putchar(' ');
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

最新文章

  1. Spring&lt;bean&gt;标签是反射来实现的
  2. iOS开发--AVFoundation自定义相机
  3. html EVENT对象
  4. Windows XP SP3下成功编译CUint2.1-3
  5. 配置suse自动化安装
  6. C#开发移动平台iOS、Android 与Windows
  7. 关于bootstrap--表格(tr的各种样式)
  8. 一般处理程序在VS2012中打开问题
  9. 用PHPExcel导出导入Excel
  10. ES6系列之解构
  11. 解决mysql插入数据报错[Err] 1146 - Table &#39;performance_schema.session_status&#39; doesn&#39;t exist
  12. idea提示不区分大小写,解决方法
  13. 小朋友学C语言(8)
  14. 【LG3247】[HNOI2016]最小公倍数
  15. Oracle数据库的基本查询
  16. CGI 、PHP-CGI、FASTCGI、PHP-FPM
  17. tiny210V2开发板hdmi输出到10.1寸LCD,无图像
  18. javascript、js操作json对象和字符串互相转换方法
  19. 修改JQM的默认配置属性
  20. php -- PHP5中file_get_contents函数获取带BOM的utf-8文件内容

热门文章

  1. vcf-tools 笔记
  2. 韦大仙--Katalon---一款好用的selenium自动化测试插件
  3. 运用GamePlayKit的GKEntity及GKComponent 的iOS游戏开发实例
  4. 小组ITalk网站开发中使用到的一些技巧
  5. Spring 配置String转Date
  6. Linux 文件的常识
  7. 小程序开发中,纯css实现内容收起折叠功能
  8. 一:yarn 介绍
  9. HDU 4568 Hunter(最短路径+DP)(2013 ACM-ICPC长沙赛区全国邀请赛)
  10. Cow Contest(最短路floyed传递闭包)