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. Shell编程基础教程2--变量和运算符

    2.变量和运算符 2.1.变量的类型 本地变量:环境变量:变量替换(显示变量):位置变量:标准变量:特殊变量: 2.2.本地变量 本地变量在用户现在的shell生命周期的脚本中使用 在命令行, LOC ...

  2. 攻城狮在路上(叁)Linux(十七)--- linux磁盘与文件管理概述

    一.复习知识点: 1.扇区是最小的物理存储单位,大小为512bytes. 2.扇区组成一个圆,成为柱面,柱面是分区的最小单位. 3.第一个扇区很重要,因为包含了MBR(446字节)和分区表(64字节) ...

  3. C# IIS应用程序池辅助类 分类: C# Helper 2014-07-19 09:50 249人阅读 评论(0) 收藏

    using System.Collections.Generic; using System.DirectoryServices; using System.Linq; using Microsoft ...

  4. shell test 數值 字符串 文件比較

    數值比較 描述 n1 –eq n2 等於 n1 –gt  n2 大於 n1 –ge n2 大於等於 n1 –lt  n2 小於 n1 –le n2 小於等於 n1 –ne n2 不等於   字符串比較 ...

  5. Sizeof与Strlen的区别与联系

    转自:http://www.cnblogs.com/carekee/articles/1630789.html 一.sizeof    sizeof(...)是运算符,在头文件中typedef为uns ...

  6. PowerDesigner(PowerDesigner15.1.0.2850)下载、安装以及破解

    转自:http://www.cnblogs.com/Fonkie/articles/1600662.html 一.先安装PowerDesigner15(PowerDesigner15.1.0.2850 ...

  7. [Unity3D]上海某大型游戏公司的基础面试题

    一个小老乡跟我聊到去上海某大公司的基础面试题,面试结果不尽如人意,但还是分享了下面试的试题,刚刚第一次录制视频,给某人讲课,我感觉讲的还算比较耐心,但发现一些新手入门学习的弊端,可能是很普遍的现象,这 ...

  8. MarkupExtension

    —目的 如果要在XAML里引用静态或动态对象实例,或在XAML中创建带有参数的类.这时,我们需要用到XAML扩展.XAML扩展常用来设定属性值.使用标识扩展,告诉 XAML 处理不要像通常那样将属性值 ...

  9. 滑动listview隐藏和显示顶部布局

    需求: 1.listview向下滑动时,隐藏顶部布局 2.listview向上滑动到最上面,显示顶部布局 3.顶部布局的隐藏和显示有过渡效果 4.第一次加载listview时,顶部不要隐藏 布局: 注 ...

  10. JavaScript模拟函数重载

    JavaScript是没有函数重载的,但是我们可以通过其他方法来模拟函数重载,如下所示: <!DOCTYPE html> <html> <head> <met ...