http://acm.hdu.edu.cn/showproblem.php?pid=4089

题意:

有n个人排队等着在官网上激活游戏。主角排在第m个。

对于队列中的第一个人。有以下情况:
1、激活失败,留在队列中等待下一次激活(概率为p1)
2、失去连接,出队列,然后排在队列的最后(概率为p2)
3、激活成功,离开队列(概率为p3)
4、服务器瘫痪,服务器停止激活,所有人都无法激活了。

求服务器瘫痪时主角在队列中的位置<=k的概率

n, m<=1000, p1+p2+p3+p4=1

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=10005;
const double eps=1e-10;
double c[N], T1[N], T2[N], p[5], T;
int n, m, K;
double abs(double x) { return x<0?-x:x; }
int main() {
while(~scanf("%d%d%d", &n, &m, &K)) {
for(int i=1; i<=4; ++i) scanf("%lf", &p[i]);
if(abs(p[4])<eps) { puts("0.00000"); continue; }
double *now=T1, *last=T2, di=1-p[1];
T=p[2]/di;
for(int i=1; i<=n; ++i) {
c[1]=p[4]/di;
for(int j=2, g=min(K, i); j<=g; ++j) c[j]=(last[j-1]*p[3]+p[4])/di;
for(int j=K+1; j<=i; ++j) c[j]=last[j-1]*p[3]/di;
double up=0, down=1;
for(int j=1; j<=i; ++j) down*=T, up*=T, up+=c[j];
now[i]=up/(1-down);
now[1]=T*now[i]+c[1];
for(int j=2; j<=i; ++j) now[j]=T*now[j-1]+c[j];
swap(now, last);
}
printf("%.5f\n", last[m]);
memset(T2, 0, sizeof(double)*(n+1));
}
return 0;
}

  

做完这题深深感到了数学题与编程题不同= =...

首先容易设计出$d[i][j]$表示一共还有i个人,主角排在了$j$位(反正一开始我没考虑到人总数对方程的影响妈呀QAQ果然还是太弱么...

容易得到:

$$
\begin{align}
d[i][1] & = d[i][1]p1 + d[i][i]p2 + p4 & j==1时 \\
d[i][j] & = d[i][j]p1 + d[i][j-1]p2 + d[i-1][j-1]p3 + p4 & j<=k时 \\
d[i][j] & = (d[i][j-1]p2 + d[i-1][j-1]p3)/(1-p1) & k<j时
\end{align}
$$

深度化简可以得到:

$$
\begin{align}
d[i][1] & = Td[i][i] + c[1] & j==1时\\
d[i][j] & = Td[i][j-1] + c[j] & j<=k时\\
d[i][j] & = Td[i][j-1] + c[j] & k<j时
\end{align}
$$

其中$T=p2/(1-p1)$, $c[j]$为那些常数项(因为$d[i-1]$的部分已经求出来了,现在只是考虑互相关系的$d[i]$,所以把$d[i-1]$看成常数)

那么这成了递归定义,发现我没只需要求出$d[i][i]$就行了...

一直递归下去可以发现,$d[i][i]=T(T(T(...Td[i][i]+c[1])+c[2])+c[3])+...+c[i]$

所以$d[i][i]=C/(1-T^i), C=T(T...T0+c[1])+c[2]+...+c[i]$

最后还要特判$p4=0$的情况啊,显然答案是0啊..(可是我发现我的程序对p4=0的情况已经免疫了啊?为啥还会waQAQ不明觉厉..反正特判一下就能对QAQ)

【HDU】4089 Activation的更多相关文章

  1. 【HDOJ】4089 Activation

    1. 题目描述长度为n的等待队列,tomato处于第m个,有如下四种可能:(1)激活失败,概率为$p_1$,队列中的顺序不变:(2)连接失败,概率为$p_2$,队头玩家重新排在队尾:(3)激活成功,概 ...

  2. 【HDU】4888 Redraw Beautiful Drawings 网络流【推断解是否唯一】

    传送门:pid=4888">[HDU]4888 Redraw Beautiful Drawings 题目分析: 比赛的时候看出是个网络流,可是没有敲出来.各种反面样例推倒自己(究其原因 ...

  3. 【HDU】2191 多重背包问题

    原题目:悼念512汶川大地震遇难同胞——珍惜现在,感恩生活 [算法]多重背包(有限背包) 动态规划 [题解]http://blog.csdn.net/acdreamers/article/detail ...

  4. 【HDU】6110 路径交(2017百度之星) 线段树+RMQ-LCA+树链的交

    [题目]2017"百度之星"程序设计大赛 - 初赛(A) [题意]给定n个点的带边权树,m条编号1~m的路径,Q次询问编号区间[L,R]所有链的交集的长度.n<=500000 ...

  5. 【HDU】6148 Valley Numer 数位DP

    [算法]数位DP [题意]定义V-number为从左到看单位数字未出现先递增后递减现象的数字,求0~N中满足条件的数字个数.T<=200,lenth(n)<=100 [题解]百度之星201 ...

  6. 【HDU】5269 ZYB loves Xor I

    [算法]trie [题解] 为了让数据有序,求lowbit无法直接排序,从而考虑倒过来排序,然后数据就会呈现出明显的规律: 法一:将数字倒着贴在字典树上,则容易发现两数的lowbit就是它们岔道结点的 ...

  7. 【HDU】3068 最长回文

    [算法]manacher [题解][算法]字符串 #include<cstdio> #include<algorithm> #include<cstring> us ...

  8. 【HDU】2222 Keywords Search

    [算法]AC自动机 [题解]本题注意题意是多少关键字能匹配而不是能匹配多少次,以及可能有重复单词. 询问时AC自动机与KMP最大的区别是因为建立了trie,所以对于目标串T与自动机串是否匹配只需要直接 ...

  9. 【HDU】6012 Lotus and Horticulture (BC#91 T2)

    [算法]离散化 [题解] 答案一定存在于区间的左右端点.与区间左右端点距离0.5的点上 于是把所有坐标扩大一倍,排序(即离散化). 让某个点的前缀和表示该点的答案. 初始sum=∑c[i] 在l[i] ...

随机推荐

  1. mipi和dsi

    转自: http://blog.csdn.net/longxiaowu/article/details/24410021 一.MIPI MIPI(移动行业处理器接口)是Mobile Industry ...

  2. Webstorm & PhpStorm的序列号和证书

    WebStorm注册码 User Name: EMBRACE License Key: ===== LICENSE BEGIN ===== 24718-12042010 00001h6wzKLpfo3 ...

  3. 算法系列:geometry

    1.基本几何变换及变换矩阵 基本几何变换都是相对于坐标原点和坐标轴进行的几何变换,有平移.比例.旋转.反射和错切等. 1.1 平移变换 是指将p点沿直线路径从一个坐标位置移到另一个坐标位置的重定位过程 ...

  4. POJ1351 Number of Locks(数学)

    截至写博客为止,貌似这是网上第一个采用数学公式来处理的. 网上的题解都是DFS或是动态规划,但感觉可以推公式直接用数学的方法处理,想了好久,终于推出公式. 题意:一个长度为n的由数字1,2,3,4 组 ...

  5. Java Hour 67 Java Collection API

    本文不是一个大而全的讲述Java Coleection 相关的APi, 而是笔者认为哪些是一个初学者所能够而且必须确切知道的知识点. Collection 一脉 这里有我们比较常用的List<E ...

  6. 6-05使用SQL语句删除数据

    删除数据语法: DELETE  FROM 表名  WHERE  删除条件. TRUNCATE  TABLE 表名. --[1]基本删除,省略WHERE条件,将删除表中的所有数据 DELETE FROM ...

  7. PHPCMS 实现上一篇、下一篇

    方法一:直接调用phpcms系统的函数 <div class="info"> <span>上一篇:<a href="{$previous_p ...

  8. 一个简单的Object Hook的例子(win7 32bit)

    Object Hook简单的来说就是Hook对象,这里拿看雪上的一个例子,因为是在win7 32位上的,有些地方做了些修改. _OBJECT_HEADER: kd> dt _OBJECT_HEA ...

  9. 阿里云 OSS+CDN

    https://promotion.aliyun.com/ntms/ossedu2.html https://www.aliyun.com/act/aliyun/ossdoc.html 对象存储(Ob ...

  10. SpringMyBatis解析1-使用示例

    MyBatis使用介绍 MyBatis的详细使用介绍  http://www.cnblogs.com/xrq730/category/796495.html 建立PO public class Per ...