题目描述

淘汰赛制是一种极其残酷的比赛制度。2n名选手分别标号1,2,3,…,2^n-1,2^n,他们将要参加n轮的激烈角逐。每一轮中,将所有参加该轮的选手按标号从小到大排序后,第1位与第2位比赛,第3位与第4位比赛,第5位与第6位比赛……只有每场比赛的胜者才有机会参加下一轮的比赛(不会有平局)。这样,每轮将淘汰一半的选手。n轮过后,只剩下一名选手,该选手即为最终的冠军。

现在已知每位选手分别与其他选手比赛获胜的概率,请你预测一下谁夺冠的概率最大。

输入输出格式

输入格式:

输入文件elimination.in。第一行是一个整数n(l≤n≤l0),表示总轮数。接下来2^n行,每行2^n个整数,第i行第j个是Pij(0≤pij≤100,Pii=0,Pij+Pji=100),表示第i号选手与第j号选手比赛获胜的概率。

输出格式:

输出文件elimination.out。只有一个整数c,表示夺冠概率最大的选手编号(若有多位选手,输出编号最小者)。

输入输出样例

输入样例#1:

  2
0 90 50 50
10 0 10 10
50 90 0 50
50 90 50 0
输出样例#1:

 1

说明

30%的数据满足n≤3;100%的数据满足n≤10。

_NOI导刊2010提高(01)

思路:

对于样例,我们可以模拟一下:

1号选手通过第1轮(进入决赛)的概率为90%,即击败2号选手的概率。同理,2号选手通过第1轮的概率为10%,3号,4号选手都是50%。

对于3号选手通过第2轮(通过第n轮夺冠)的概率,我们可以分情况讨论。假设3号选手已经通过第1轮。如果1号选手通过第1轮(90%的可能性),则3号选手通过第2轮的概率为50%,即击败1号选手的概率,所以3号选手击败1号选手通过第2轮的概率为90%*50%=45%;如果2号选手通过第1轮(10%的可能性),则3号选手通过第2轮的概率为90%,即击败2号选手的概率,所以3号选手击败2号选手通过第2轮的概率为10%*90%=9%。所以3号选手击败对手通过第2轮的概率为45%+9%=54%,而这是在3号选手已经通过第1轮的基础上的概率,自然,3号选手最初时通过第2轮的概率只有50%*54%=27%。

同理,4号选手最初时通过第2轮的概率为27%,1号选手通过第2轮的概率为45%,2号选手为1%,45%>27%>27%>1%,所以答案输出1。

所以:每一位选手通过这一轮的概率为这一位选手通过上一轮的概率乘上这一位选手击败这一轮遇到的每一个对手的概率之和

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,num;
double maxn=-;
double map[][];
double f[],ff[];
int main(){
scanf("%d",&n);
num=pow(,n);
for(int i=;i<=num;i++)
for(int j=;j<=num;j++){
int x;
scanf("%d",&x);
map[i][j]=x*1.0/*1.0;
}
for(int i=;i<=num;i++)
if(i%==) f[i]=map[i][i-];
else f[i]=map[i][i+];
for(int i=;i<=n;i++){
for(int j=;j<=num;j++){
double bns=;
int l,r,aa=pow(,i-),tmp=(j-)/aa;
if(tmp%==){ l=aa*(tmp+)+; r=aa*(tmp+); }
else{ l=aa*(tmp-)+; r=aa*tmp; }
for(int k=l;k<=r;k++)
bns+=f[k]*map[j][k];
ff[j]=f[j]*bns;
}
for(int j=;j<=num;j++)
f[j]=ff[j];
}
int ans;
for(int i=;i<=num;i++)
if(f[i]>maxn){
ans=i;
maxn=f[i];
}
cout<<ans;
}

最新文章

  1. VS2010/VS2013中ashx代码折叠的问题
  2. scala 学习之:List fold, foldLeft方法
  3. [BZOJ1264][AHOI2006]Match(DP+树状数组)
  4. Java之POJO
  5. Linux网络共享管理(ssh,nfs,samba)
  6. 存储区更新、插入或删除语句影响到了意外的行数(0)。实体在加载后可能被修改或删除。刷新 ObjectStateManager 项。
  7. Epic - Tic Tac Toe
  8. Java Script基础(七) HTML DOM模型
  9. ARP 实现
  10. PHPEXCEL导入小技巧
  11. 『备注』GDI+ 绘制文本有锯齿,透明背景文本绘制
  12. P1-Linux下安装MySQL及登录用户配置
  13. Matlab中要显示数学公式或符号Latex
  14. unbuntu 16.04.2 安装 Eclipse C++开发环境
  15. Java发送邮件时标题和发件人乱码
  16. Antd-Select组件的深入用法
  17. 字典学习(Dictionary Learning, KSVD)详解
  18. 解题:国家集训队 Middle
  19. vue项目启动出现cannot GET /服务错误
  20. 在控制台中操作MYSQL数据库步骤以及一些小问题

热门文章

  1. LightOJ-1259 Goldbach`s Conjecture 数论 素数筛
  2. POJ-3159 Candies 最短路应用(差分约束)
  3. [USACO4.2]完美的牛栏The Perfect Stall
  4. 【Python常见问题总结】
  5. vux安装时报vux-loader配置问题
  6. C语言计算字符串数组中每个字符串出现的个数
  7. 简单搭建zookeeper集群分布式/伪分布式
  8. SVN配置以及自己主动部署到apache虚拟文件夹
  9. Android中的消息机制
  10. springMVC之拦截器