【五校联考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. xshell连接windows10子系统ubuntu

    修改端口 cd /etc/ssh#备份sudo cp sshd_config sshd_config.baksudo vim sshd_config修改sshd_config Port 2233 #修 ...

  2. Linux下开发环境的搭建(For C++ OIer)

    说句实话,对于OIer来说,Linux真的是个很好的开发平台. 这里既没有游戏的喧嚣,也没有广告的打扰,gcc/g++早已预装,一切已为你准备好......(???)即使对于日常使用,也绰绰有余. 如 ...

  3. .netcore 简单使用ElasticSearch

    .netcore 简单使用ElasticSearch(7.6) 最近在捣鼓学习了下ElasticSearch,在此记录下使用.netcore操作elastic search 的实现(简单的封装,使用) ...

  4. 14 RPC

    14 RPC RPC(Remote Procedure Call Protocol)--远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC协议假定某些 ...

  5. 《精通Spring4.x企业应用开发实战》第二章

    昨天联系了一下学长,学长说这个项目因为种种原因代码比较混乱,感觉最坏的打算是从头开始写. 大概询问了一下学长和xianhua学姐的建议,又看了看网上的资料,这个项目开发的技术栈基本就是SpringBo ...

  6. C#实现的几种委托方式介绍

    //普通委托            DeleteShow ds = new DeleteShow(ShowName);            Console.WriteLine("----- ...

  7. javaweb项目中jsp的from表单提交action内容与web.xml的servlet-mapping对应

    login.jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> ...

  8. Netlink 内核实现分析 4

    netlink 库函数: http://www.infradead.org/~tgr/libnl/doc/core.html#core_netlink_fundamentals #define NET ...

  9. 异常记录-Dialog样式踩坑

    好久没记录文档了,拖了老半个月,终于空下来时间,为了避免以后踩坑,必须记录记录. 背景: 为activity设置样式为弹窗activity 异常一: activity设置style后,布局不能够正常显 ...

  10. Java中5种List的去重方法及它们的效率对比,你用对了吗?

    01.使用两个for循环实现List去重(有序) /**使用两个for循环实现List去重(有序)     *     * @param list     * */    public static  ...