火山喷发对所有附近的生物具有毁灭性的影响。在本题中,我们希望用数值来模拟这一过程。

在环境里有 nnn 个生物分别具有 A1,A2,⋯,An​​点生命值,一次火山喷发总计 M轮,每轮造成 1点伤害,等概率地分给所有存活的生物,即如果目前有 K 个活着的生物,每个生物受到这点伤害的概率是 1/K​​。如果一个生物的生命值减为 0,它会立即死去,此后都不会再占用受到伤害的概率。如果没有生物存活,那么将没有生物会受到伤害。

现在你的任务是,给定 n,M 和全部生物的生命值,问每个生物火山喷发后依然存活的概率。

输入格式
第一行两个正整数 n 和 M。
第二行 n 个正整数 A1,...,An。

输出格式
n行,第 i 行一个数表示第 i 个生物存活下来的概率,保留小数点后六位。

数据范围与约定
对于 10% 的数据 N=1。
对于 30% 的数据 N=2。
对于全部数据 N≤4,M≤120,A​i​​≤50。

样例输入1

1 2
1

样例输出1

0.000000

样例输入2

3 15
2 12 2

样例输出2

0.001684
0.996632
0.001684
f[i][j][k][p]表示生命值为i,j,k,p时的概率

那么我们枚举轮数和4个生物的HP,就可以转移

但是O(120*50^4)显然超时

但我们知道轮数和3个生物的HP,显然可以推出第四个

所以O(120*50^3)就够了

还有要注意枚举的HP对应的损失HP必须等于轮数

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
double cnt,f[][][][],ans;
int n,a[],m;
int main()
{int l,i,j,k,p;
cin>>n>>m;
for (i=;i<=n;i++)
scanf("%d",&a[i]);
m=min(m,a[]+a[]+a[]+a[]);
f[a[]][a[]][a[]][a[]]=;
for (l=;l<=m;l++)
{
for (i=;i<=a[];i++)
{
for (j=;j<=a[];j++)
{
for (k=;k<=a[];k++)
{
int p=a[]-(l-(a[]-i)-(a[]-j)-(a[]-k));
if (a[]-i+a[]-j+a[]-p+a[]-k!=l) continue;
if (p<||p>a[]) continue;
if (f[i][j][k][p]==) continue;
cnt=;
if (i) cnt++;if (k) cnt++;
if (j) cnt++;if (p) cnt++;
if (cnt==) continue;
if (i) f[i-][j][k][p]+=f[i][j][k][p]/cnt;
if (j) f[i][j-][k][p]+=f[i][j][k][p]/cnt;
if (k) f[i][j][k-][p]+=f[i][j][k][p]/cnt;
if (p) f[i][j][k][p-]+=f[i][j][k][p]/cnt;
}
}
}
}
for (i=;i<=n;i++)
{ans=;
if (i==)
for (j=;j<=a[];j++)
for (k=;k<=a[];k++)
for (p=;p<=a[];p++)
if (a[]+a[]-j+a[]-k+a[]-p==m)
ans+=f[][j][k][p];
if (i==)
for (j=;j<=a[];j++)
for (k=;k<=a[];k++)
for (p=;p<=a[];p++)
if (a[]-j+a[]+a[]-k+a[]-p==m)
ans+=f[j][][k][p];
if (i==)
for (j=;j<=a[];j++)
for (k=;k<=a[];k++)
for (p=;p<=a[];p++)
if (a[]-j+a[]-k+a[]+a[]-p==m)
ans+=f[j][k][][p];
if (i==)
for (j=;j<=a[];j++)
for (k=;k<=a[];k++)
for (p=;p<=a[];p++)
if (a[]-j+a[]-k+a[]-p+a[]==m)
ans+=f[j][k][p][];
printf("%.6lf\n",-ans);
}
}

计蒜客 NOIP模拟赛(3) D1T1火山喷发的更多相关文章

  1. 计蒜客NOIP模拟赛(2) D1T1邻家男孩

    凡是一个具有领导力的孩子.现实生活中他特别喜欢玩一个叫做 UNO 的纸牌游戏,他也总是带着其他小朋友一起玩,然后战胜他们.慢慢地,他厌倦了胜利,于是准备发明一种新的双人纸牌游戏. 初始时,每个人手中都 ...

  2. 计蒜客NOIP模拟赛5 D1T1 机智的 AmyZhi

    那年一个雨季,AmyZhi 在校门外弯身买参考书. 这时 SiriusRen 走过来,一言不合甩给她一道“自认为”很难的题: --------------- 给你一个数字 NN(NN 的范围是 11  ...

  3. 计蒜客NOIP模拟赛4 D1T1 小X的质数

    小 X 是一位热爱数学的男孩子,在茫茫的数字中,他对质数更有一种独特的情感.小 X 认为,质数是一切自然数起源的地方. 在小 X 的认知里,质数是除了本身和 1以外,没有其他因数的数字. 但由于小 X ...

  4. 计蒜客NOIP模拟赛6 D1T1Diamond-square

    Diamond-square 算法是一种能够用于生成噪声的算法,现在我们考虑这个算法的一个变种. 你有一个 2^n\times 2^n2​n​​×2​n​​ 的网格,一共有 (2^n+1)^2(2​n ...

  5. 计蒜客NOIP模拟赛4 D2T1 鬼脚图

    鬼脚图,又称画鬼脚,在日本称作阿弥陀签,是一种经典游戏,也是一种简易的决策方法,常常用来抽签或决定分配组合. 下图就是一张鬼脚图,其包含若干条竖线和若干条横线.请注意,横线只能水平连接相邻的两条竖线, ...

  6. 计蒜客NOIP模拟赛4 D2T2 跑步爱天天

    YOUSIKI 在 noip2016 的一道<天天爱跑步>的题爆零后,潜心研究树上问题,成为了一代大师,于是皮皮妖为了测验他,出了一道题,名曰<跑步爱天天>. 有一个以 1 为 ...

  7. 计蒜客NOIP模拟赛4 D1T3 小X的佛光

    小 X 是远近闻名的学佛,平日里最喜欢做的事就是蒸发学水. 小 X 所在的城市 X 城是一个含有 N 个节点的无向图,同时,由于 X 国是一个发展中国家,为了节约城市建设的经费,X 国首相在建造 X ...

  8. 计蒜客NOIP模拟赛4 D1T2小X的密室

    小 X 正困在一个密室里,他希望尽快逃出密室. 密室中有 N 个房间,初始时,小 X 在 1 号房间,而出口在 N 号房间. 密室的每一个房间中可能有着一些钥匙和一些传送门,一个传送门会单向地创造一条 ...

  9. 计蒜客NOIP模拟赛D2T3 数三角形

    刚刚上高中的洁洁在学习组合数学的过程中遇到一道麻烦的题目,她希望你能帮助她解决.给定一张无向完全图 G,其中大部分边被染成蓝色,但也有一些边被染成红色或者绿色.现在,洁洁需要给这张图的多样性进行打分. ...

随机推荐

  1. Linux下进程间通信的六种机制详解

    linux下进程间通信的几种主要手段:        1.管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具 ...

  2. Session的过期时间如何计算?

    在生成session的时候,会设置一个session过期时间.session的过期时间并不是从生成session对象开始计算,超过过期时间,session就失效了. 而是每当一个浏览器请求,sessi ...

  3. Windows Server2012 故障转移集群之动态仲裁(Dynamic Quorum)

    本篇文章主要介绍Windows2012的故障转移集群一个新功能“动态仲裁”,默认该功能是开启的: 动态仲裁能在当前群集投票出现分歧的情况下取消某些节点的投票权限,比如偶数个节点的群集环境.仲裁见证和动 ...

  4. Gson解析Json数组

    需求:从steam官网获取英雄数据,即为Json数据,并导入到本地数据库 Json数据是这样的 { "result": { "heroes": [ { &quo ...

  5. [翻译]现代java开发指南 第三部分

    现代java开发指南 第三部分 第三部分:Web开发 第一部分,第二部分,第三部分 =========================== 欢迎来到现代 Java 开发指南第三部分.在第一部分中,我们 ...

  6. 优化从 App.config 读取配置文件

    public class AppSettingsConfig { /// <summary> ////// </summary> public static int Query ...

  7. Linq 对象的比较 Contains,Max

    IList<Student> studentList = new List<Student>() { new Student() { StudentID = 1, Studen ...

  8. restful架构风格设计准则(一)以资源为中心、自描述的请求响应、资源状态迁移为粒度

    读书笔记,原文链接:http://www.cnblogs.com/loveis715/p/4669091.html,感谢作者! 一.需求描述 当用户在某个电子商务网站购物时,他首先查看要购买的商品分类 ...

  9. 【52ABP实战教程】0.3-- 从github推送代码回vsts实现双向同步

    需求 在之前的文章中"[DevOps]如何用VSTS持续集成到Github仓库" 我们有讲述如何将vsts中的代码编译推送到github中,这一篇我们来完善,如果有人给你开源项目推 ...

  10. 译《Time, Clocks, and the Ordering of Events in a Distributed System》

    Motivation <Time, Clocks, and the Ordering of Events in a Distributed System>大概是在分布式领域被引用的最多的一 ...