Josephina and RPG

Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 929    Accepted Submission(s):
265
Special Judge

Problem Description
A role-playing game (RPG and sometimes roleplaying
game) is a game in which players assume the roles of characters in a fictional
setting. Players take responsibility for acting out these roles within a
narrative, either through literal acting or through a process of structured
decision-making or character development.
Recently, Josephina is busy playing
a RPG named TX3. In this game, M characters are available to by selected by
players. In the whole game, Josephina is most interested in the "Challenge Game"
part.
The Challenge Game is a team play game. A challenger team is made up of
three players, and the three characters used by players in the team are required
to be different. At the beginning of the Challenge Game, the players can choose
any characters combination as the start team. Then, they will fight with N AI
teams one after another. There is a special rule in the Challenge Game: once the
challenger team beat an AI team, they have a chance to change the current
characters combination with the AI team. Anyway, the challenger team can insist
on using the current team and ignore the exchange opportunity. Note that the
players can only change the characters combination to the latest defeated AI
team. The challenger team gets victory only if they beat all the AI
teams.
Josephina is good at statistics, and she writes a table to record the
winning rate between all different character combinations. She wants to know the
maximum winning probability if she always chooses best strategy in the game. Can
you help her?
 
Input
There are multiple test cases. The first line of each
test case is an integer M (3 ≤ M ≤ 10), which indicates the number of
characters. The following is a matrix T whose size is R × R. R equals to C(M,
3). T(i, j) indicates the winning rate of team i when it is faced with team j.
We guarantee that T(i, j) + T(j, i) = 1.0. All winning rates will retain two
decimal places. An integer N (1 ≤ N ≤ 10000) is given next, which indicates the
number of AI teams. The following line contains N integers which are the IDs
(0-based) of the AI teams. The IDs can be duplicated.
 
Output
For each test case, please output the maximum winning
probability if Josephina uses the best strategy in the game. For each answer, an
absolute error not more than 1e-6 is acceptable.
 
Sample Input
4
0.50 0.50 0.20 0.30
0.50 0.50 0.90 0.40
0.80 0.10 0.50 0.60
0.70 0.60 0.40 0.50
3
0 1 2
 
Sample Output
0.378000
 
 /*                    dp[i+1][j]
dp[i][j]=
dp[i+1][num[i]]
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
#include<set>
#include<map>
#include<vector>
#include<stack>
#include<queue>
using namespace std;
const int ms=;
const int cms=;
const int MAXN=;
double dp[MAXN][cms];
double p[cms][cms];
int num[MAXN];
int main()
{
int i,j,k,t,n,m,cnt;
while(scanf("%d",&n)!=EOF)
{
for(cnt=,i=n;i>=(n-+);i--)
cnt*=i;
cnt/=;
for(i=;i<cnt;i++)
for(j=;j<cnt;j++)
scanf("%lf",&p[i][j]);
scanf("%d",&m);
for(i=;i<=m;i++)
scanf("%d",&num[i]);
for(i=;i<=cnt;i++)
dp[m+][i]=1.0;
for(i=m;i>;i--)
{
for(j=;j<cnt;j++)
{
dp[i][j]=p[j][num[i]]*max(dp[i+][j],dp[i+][num[i]]);
}
}
double ans=-1.0;
for(j=;j<cnt;j++)
if(ans<dp[][j])
ans=dp[][j];
printf("%.6lf\n",ans);
}
return ;
}

Josephina and RPG的更多相关文章

  1. 2013长沙赛区现场赛 J - Josephina and RPG

    J - Josephina and RPG Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I6 ...

  2. hdu4800 Josephina and RPG 解题报告

    Josephina and RPG Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  3. Josephina and RPG HDU - 4800

    A role-playing game (RPG and sometimes roleplaying game) is a game in which players assume the roles ...

  4. DP ZOJ 3735 Josephina and RPG

    题目传送门 题意:告诉你C(m,3)个队伍相互之间的胜率,然后要你依次对战n个AI队伍,首先任选一种队伍,然后战胜一个AI后可以选择替换成AI的队伍,也可以不换,问你最后最大的胜率是多少. 分析:dp ...

  5. hdu 4800 Josephina and RPG

    简单dp #include<cstdio> #define maxn 10005 #include<cstring> #include<algorithm> usi ...

  6. HDU 4800/zoj 3735 Josephina and RPG 2013 长沙现场赛J题

    第一年参加现场赛,比赛的时候就A了这一道,基本全场都A的签到题竟然A不出来,结果题目重现的时候1A,好受打击 ORZ..... 题目链接:http://acm.hdu.edu.cn/showprobl ...

  7. The 2013 ACM-ICPC Asia Changsha Regional Contest - J

    Josephina and RPG Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge A role-playin ...

  8. 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...

  9. 【经典】C++&RPG对战游戏

    博文背景: 还记大二上学期的时候看的这个C++&RPG游戏(博主大一下学期自学的php,涵盖oop内容),一个外校的同学他们大一学的C++,大二初期C++实训要求做一个程序填空,就是这个 RP ...

随机推荐

  1. 过度拟合(overfitting)

    我们之前解决过一个理论问题:机器学习能不能起作用?现在来解决另一个理论问题:过度拟合. 正如之前我们看到的,很多时候我们必须进行nonlinear transform.但是我们又无法确定Q的值.Q过小 ...

  2. bzoj 2002 [Hnoi2010]Bounce 弹飞绵羊(LCT)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2002 [题意] 给定n个数的序列,i可以跳到i+k[i],需要能够修改k并可以查询跳出 ...

  3. IO-同步,异步,阻塞,非阻塞,阅读摘要

    http://www.cnblogs.com/Fly-Wind/p/io.html http://blog.csdn.net/historyasamirror/article/details/5778 ...

  4. web.py处理文件上传

    #coding=utf8 import web urls = ('/','Home', '/upload', 'Upload') app = web.application(urls, globals ...

  5. FMX架构图

  6. 微服务架构下分布式Session管理

    转载本文需注明出处:EAII企业架构创新研究院(微信号:eaworld),违者必究.如需加入微信群参与微课堂.架构设计与讨论直播请直接回复此公众号:“加群 姓名 公司 职位 微信号”. 一.应用架构变 ...

  7. POJ 3660 Cow Contest(传递闭包floyed算法)

    Cow Contest Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5989   Accepted: 3234 Descr ...

  8. js面形对象(2)

    1.​原型与in操作符     有两种方式使用in操作符:单独使用和在for-in循环中使用.在单独使用时,in操作符会在通过对象能够访问给定属性时,返回true,无论该属性是存在实例或者是存在于原型 ...

  9. jQuery 源码解析一:jQuery 类库整体架构设计解析

    如果是做 web 的话,相信都要对 Dom 进行增删查改,那大家都或多或少接触到过 jQuery 类库,其最大特色就是强大的选择器,让开发者脱离原生 JS 一大堆 getElementById.get ...

  10. MEF 编程指南(二):定义可组合部件和契约

    可组合部件(Composable Parts)   在 MEF 内部可组合部件是一个可组合单元.可组合部件导出其他可组合部件需要的服务,并且从其他可组合部件导入服务.在 MEF 编程模型中,可组合部件 ...