博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
poj 3744 Scout YYF I (矩阵)
阅读量:6481 次
发布时间:2019-06-23

本文共 2793 字,大约阅读时间需要 9 分钟。

Description

YYF is a couragous scout. Now he is on a dangerous mission which is to penetrate into the enemy's base. After overcoming a series difficulties, YYF is now at the start of enemy's famous "mine road". This is a very long road, on which there are numbers of mines. At first, YYF is at step one. For each step after that, YYF will walk one step with a probability of p, or jump two step with a probality of 1-p. Here is the task, given the place of each mine, please calculate the probality that YYF can go through the "mine road" safely.

 

Input

The input contains many test cases ended with EOF.Each test case contains two lines.The First line of each test case is N (1 ≤ N ≤ 10) and p (0.25 ≤ p ≤ 0.75) seperated by a single blank, standing for the number of mines and the probability to walk one step.The Second line of each test case is N integer standing for the place of N mines. Each integer is in the range of [1, 100000000].

 

Output

For each test case, output the probabilty in a single line with the precision to 7 digits after the decimal point.

 

Sample Input

1 0.522 0.52 4

 

Sample Output

0.50000000.2500000

 

Source

, Simon
 

又是一题矩阵乘法……

这题很显然了, n个雷,分别在 a[1]...a[n] ,走一步概率为 p ,走两步概率为 1-p ,一开始在 1 号位置,问安全到达终点的概率。

显然,如果k 号位有雷,那么安全通过这个雷只可能是在 k-1 号位选择走两步到 k+1 号位。因此,可以得到如下结论:在第 i 个雷的被处理掉的概率就是从 a[i-1]+1 号位到 a[i] 号位的概率。于是,可以用 1 减去就可以求出安全通过第 i 个雷的概率,最后乘起来即可,比较悲剧的是数据很大,所以需要用到矩阵快速幂……

类似斐波那契数列,有ans[i]=p*ans[i-1]+(1-p)*ans[i-2] ,构造矩阵为

 

|p  1-p |     ans[i-1]   ans[i]

|1  0    |     ans[i-2]  ans[i-1] 

 

 

1 //ans[i]=p*ans[i-1]+(1-p)*ans[i-2] 2 #include
3 #include
4 #include
5 #include
6 #include
7 #include
8 using namespace std; 9 #define N 1610 int n;11 double p;12 int a[N];13 14 struct Matrix15 {16 double m[3][3];17 Matrix()18 {19 memset(m,0,sizeof(m));20 for(int i=0;i<2;i++)21 m[i][i]=1;22 }23 };24 25 Matrix Mul(Matrix a,Matrix b)26 {27 Matrix res;28 int i,j,k;29 for(int i=0;i<2;i++)30 {31 for(int j=0;j<2;j++)32 {33 res.m[i][j]=0;34 for(int k=0;k<2;k++)35 {36 res.m[i][j]=res.m[i][j]+(a.m[i][k]*b.m[k][j]);37 }38 }39 }40 return res;41 }42 Matrix fastm(Matrix a,int b)43 {44 Matrix res;45 while(b)46 {47 if(b&1)48 res=Mul(res,a);49 a=Mul(a,a);50 b>>=1;51 }52 return res;53 }54 55 int main()56 {57 while(scanf("%d%lf",&n,&p)!=EOF)58 {59 for(int i=1;i<=n;i++) scanf("%d",&a[i]);60 61 sort(a+1,a+n+1);62 double ans=1;63 Matrix tmp;64 tmp.m[0][0]=p;65 tmp.m[0][1]=1-p;66 tmp.m[1][0]=1;67 tmp.m[1][1]=0;68 69 Matrix cnt;70 cnt=fastm(tmp,a[1]-1);71 ans*=(1-cnt.m[0][0]);72 for(int i=2;i<=n;i++)73 {74 if(a[i]==a[i-1]) continue;75 cnt=fastm(tmp,a[i]-a[i-1]-1);76 ans*=(1-cnt.m[0][0]);77 }78 79 printf("%.7lf\n",ans);80 81 }82 return 0;83 }
View Code

 

 

转载地址:http://qbfuo.baihongyu.com/

你可能感兴趣的文章
RedHat 6 配置iSCSI服务
查看>>
Oracle tablespace maxsize解析
查看>>
测试人员,你的价值不是你的工资
查看>>
实践无用论:這個"實踐"是動詞!!
查看>>
Puppet 条件判断语句(十六)
查看>>
使用haproxy-实现七层负载均衡
查看>>
windows系统 中 如何获取当前帐号的 SID 值
查看>>
Android应用程序与SurfaceFlinger服务的连接过程分析
查看>>
perl学习笔记(5)
查看>>
【VMCloud云平台】SCVMM配置(七)创建SQL服务模板之SQL配置文件
查看>>
内容类型(ContentType)与文件扩展名(Extension)相互映射
查看>>
Java单元测试Junit的Annotation介绍
查看>>
使用Spring3.x框架的java mail支持来发送邮件
查看>>
MotoRola MT870 ROOT及刷机方法
查看>>
【VMCloud云平台】SCOM配置(十四)-安装SCOM日志审计(ACS)
查看>>
android studio命令行错误gradlew: Permission denied
查看>>
时间是创业最核心的资源
查看>>
如何躲开“责任”的逆袭——别让猴子跳回背上(续)
查看>>
Zabbix监控Linux、Windows主机
查看>>
linux网卡配置和双网卡绑定小贴士
查看>>