【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你

题目

Description

因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一些人,小R 自然也参加了。

这个游戏有n 个人参加,每一轮随机选出一个还没有出局的人x,接着x 会出局。x 在出局之后剩下的人会受到一次攻击,每一个人在遭到攻击之后会有p 的概率出局。(注意遭到攻击出局的人是不能攻击剩下的人的)

在所有人都出局之后,遭受攻击次数等于特定值的人能够成为胜者。所以现在小R 想要知道对于每一个0 <= k < n,自己恰好在遭受k 次攻击之后出局的概率是多少。(这里的出局指的不是被攻击出局)

注意在这题中,所有数值的运算在模258280327 的意义下进行。

Input

第一行输入一个正整数T 表示数据组数。

对于每一组数据输入仅一行三个数n, x, y,表示在这组数据中有n 个人参赛,p = x/y。保证y 和258280327 互质。

Output

对于每组数据,输出一行n 个整数,表示对于k = 0到n - 1 的概率在模258280327 意义下的值。

Sample Input

2

3 40 100

9 32 1049

Sample Output

172186885 92980918 16529941

229582513 163885050 39458156 102374877 116777758 216371874 55544199 95860736 8136787

Data Constraint

对于60% 的数据,n <=100

对于100% 的数据,n <= 2* 10^3^,1 <= T <= 5,0<= x < y <= 10^9^

题解

题意

有\(n\)个人(包括主人公小\(R\))

每一轮会在剩余活人里随机选一个人,让他攻击除他之外的所有活人,然后他挂掉

所有人受到攻击后会有\(p\)的概率挂掉

问主人公小\(R\)经过\(k(0≤k≤n-1)\)次攻击后挂掉(注意不是攻击挂掉,是被抽到挂掉)的概率

分析

易想到概率\(DP\)

容易发现每个人(除小\(R\)外)都是一个\(NPC\),他们挂掉的顺序我们不用在意 (残忍)

那么可以编号

规定第\(i\)个人在第\(i\)轮被抽到

设\(f[i][j]\)表示现在第\(i\)个人要挂掉,第\(i-1\)个人到第\(n\)个人都还活着,每个人都被进攻了\(j\)次

那么转移:

\(f[i][j]+=f[i-1][j]*(1-(1-p)^j)+f[i-1][j-1]*(1-p)^{j-1}\)

解释:

首先\(f[i][j]\)可以从两个方面转移

一是之前被进攻了\(j-1\)次没挂,这次挂了

二是之前进攻都没死,现在被抽到要挂掉了

那么转移方程的前半对应一,后半对应二

自己想一想

答案为

\(Ans(j)=\sum_{i=0}^{n-1}*\dfrac{1}{n}*(1-p)^j\)

转移即可

Code

#include<cstdio>
#include<cstring>
#define mod 258280327
using namespace std;
int t,n,x,y,i,j;
long long p,ans,mdn,pow[2005],f[2005][2005];
long long ksm(long long x,long long y)
{
long long res;
res=1;
while(y)
{
if (y&1) res=res*x%mod;
y>>=1;
x=x*x%mod;
}
return res;
}
int main()
{
scanf("%d",&t);
while (t--)
{
scanf("%d%d%d",&n,&x,&y);
mdn=ksm(n,mod-2);
p=(1-x*ksm(y,mod-2)%mod+mod)%mod;
for (i=0;i<=n;i++)
pow[i]=ksm(p,i);
memset(f,0,sizeof(f));
f[0][0]=1;
for (i=1;i<=n;i++)
for (j=0;j<=i;j++)
f[i][j]=((f[i][j]+f[i-1][j]*(1-pow[j]+mod)%mod)%mod+f[i-1][j-1]*pow[j-1]%mod)%mod;
for (j=0;j<n;j++)
{
ans=0;
for (i=0;i<n;i++)
ans=(ans+(f[i][j]*mdn%mod)*pow[j]%mod)%mod;
printf("%lld ",ans);
}
printf("\n");
}
return 0;
}

【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你的更多相关文章

  1. 【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底

    [五校联考1day2]JZOJ2020年8月12日提高组T1 对你的爱深不见底 题目 Description 出乎意料的是,幸运E 的小R 居然赢了那个游戏.现在欣喜万分的小R 想要写一张明信片给小Y ...

  2. 【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划

    [GDKOI2014]JZOJ2020年8月13日提高组T2 石油储备计划 题目 Description Input Output 对于每组数据,输出一个整数,表示达到"平衡"状态 ...

  3. JZOJ2020年8月11日提高组T2 宝石

    JZOJ2020年8月11日提高组T2 宝石 题目 Description 见上帝动了恻隐之心,天后也想显示一下慈悲之怀,随即从口袋中取出一块魔术方巾,让身边的美神维纳斯拿到后堂的屏风上去试试,屏风是 ...

  4. JZOJ2020年8月12日提高组反思

    JZOJ2020年8月12日提高组反思 真·难亿一点点 T1 题目长并附带伤害-- 暴力搜 对于字符串,我选择\(Pascal\) T2 概率问题,再见 T3 样例没懂,再见 T4 有史以来见过的条件 ...

  5. 【佛山市选2013】JZOJ2020年8月7日提高组T2 树环转换

    [佛山市选2013]JZOJ2020年8月7日提高组T2 树环转换 题目 描述 给定一棵N个节点的树,去掉这棵树的一条边需要消耗值1,为这个图的两个点加上一条边也需要消耗值1.树的节点编号从1开始.在 ...

  6. 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换

    [NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...

  7. JZOJ2020年8月11日提高组T4 景点中心

    JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ...

  8. JZOJ2020年8月11日提高组T3 页

    JZOJ2020年8月11日提高组T3 页 题目 Description 战神阿瑞斯听说2008年在中华大地上,将举行一届规模盛大的奥林匹克运动会,心中顿觉异常兴奋,他想让天马在广阔的天空上,举行一场 ...

  9. JZOJ2020年8月11日提高组T1 密码

    JZOJ2020年8月11日提高组T1 密码 题目 Description 在浩浩茫茫的苍穹深处,住着上帝和他的神仆们,他们闲谈着下界的凡人俗事,对人世间表现的聪明智慧,大加赞赏.今天他们正在观赏大地 ...

随机推荐

  1. 使用Apache Hudi + Amazon S3 + Amazon EMR + AWS DMS构建数据湖

    1. 引入 数据湖使组织能够在更短的时间内利用多个源的数据,而不同角色用户可以以不同的方式协作和分析数据,从而实现更好.更快的决策.Amazon Simple Storage Service(amaz ...

  2. 解决Affter Effect汉化版(cc2015之后的版本)中出现表达式错误的一种常用方法

    解决Affter Effect出现表达式错误的一种常用方法 问题:汉化版的AE中,使用模板会出现表达式错误之类的提示,可能会导致某些设置或者效果失效 解决办法: 方法一.将配置文件中的zh_CN 改为 ...

  3. 为研发同学定制的MySQL面试指南 - “能谈谈基数统计吗?”

    ** 目录 推荐阅读原文链接 一.基数是啥? 二.InnoDB更新基数的时机? 三.基数是估算出来 四.持久化基数 四.如何主动更新基数? 欢迎关注 Hi,大家好!我是白日梦. 今天我要跟你分享的话题 ...

  4. 【SpringBoot】08.SpringBoot整合jsp

    SpringBoot整合jsp 1.修改pom文件加入两个坐标jstl标签库和jasper <project xmlns="http://maven.apache.org/POM/4. ...

  5. 查看并配置JAVA_HOME

    转载自https://blog.csdn.net/weixin_41713592/article/details/79941418which java [root@host2 hadoop-1.1.2 ...

  6. 10、Django与Ajax

    AJAX准备知识:JSON 什么是 JSON ? JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据交换格式 JS ...

  7. python爬虫06取当当网 Top 500 本五星好评书籍

    主要思路 使用 page 变量来实现翻页 我们使用 requests 请求当当网 然后将返回的 HTML 进行正则解析 由于我们暂时还没学到数据库 所以解析完之后就把内容存到文件中 def main( ...

  8. Prometheus监控告警浅析

    前言 最近有个新项目需要搞一套完整的监控告警系统,我们使用了开源监控告警系统Prometheus:其功能强大,可以很方便对其进行扩展,并且可以安装和使用简单:本文首先介绍Prometheus的整个监控 ...

  9. BIM+GIS它们各有什么优缺点

    BIM+GIS它们各有什么优缺点?应用有哪些优势?BIM模型精细程度高,语义信息丰富,侧重整合和管理建筑物自身所有阶段信息,包括建筑物所有微观图形化和非图形化信息,三维GIS侧重宏观.大范围地理环境与 ...

  10. python_socket登陆验证_明文

    client.py import socket import struct sk=socket.socket() sk.connect(('127.0.0.1',9005)) while True: ...