计算最大游戏胜率
游戏中心新出了一种游戏,名叫"三连胜",规则很简单:首先从三场比赛中选出任何一场,然后对于每一个选定的比赛,猜三个可能的结果中的一个------即W代表赢,T代表平,L代表输。每个结果都给定一个胜率。赢家的胜率将是三个单场胜率相乘之后再乘以65%的乘积。
例如,3场比赛的胜率如下:
W T L
1.1 2.5 1.7
1.2 3.1 1.6
4.1 1.2 1.1
为了获得最大的胜率,我们必须选择第三局的W,第二局的T,第一局的T。如果常数为2,则最大胜率为(4.1×3.1×2.5×65%-1)×2=39.31(精确到小数点后2位)。
输入格式:
每个输入包含一个测试用例,测试用例包括三行,分别对应三场比赛的胜率,每一行依次给出每一场比赛赢、平、负的胜率。
输出格式:
对每一组输入,输出最佳选择以及可能赢得的最大胜率。胜率精确到小数点后两位,选择和胜率之间使用空格分隔。
输入样例:
在这里给出一组输入。例如:
1.1 2.5 1.7
1.2 3.1 1.6
4.1 1.2 1.1
输出样例:
在这里给出相应的输出。例如:
T T W 39.31
代码:
c
#include<stdio.h>
int main(void)
{
float a[3][3];
float out[3][3][3];
float max;
int s123[3];
for(int s=0;s<3;s++)
{
for(int m=0;m<3;m++)
{
scanf("%f",&a[s][m]);
}
}
for(int s1=0;s1<3;s1++)
{
for(int s2=0;s2<3;s2++)
{
for(int s3=0;s3<3;s3++)
{
out[s1][s2][s3]=(a[0][s1]*a[1][s2]*a[2][s3]*0.65-1)*2;
}
}
}
max=0;
for(int s1=0;s1<3;s1++)
{
for(int s2=0;s2<3;s2++)
{
for(int s3=0;s3<3;s3++)
{
if(max<out[s1][s2][s3])
{
max=out[s1][s2][s3];
s123[0]=s1;
s123[1]=s2;
s123[2]=s3;
}
}
}
}
for(int i=0;i<3;i++)
{
if(s123[i]==0)printf("W ");
if(s123[i]==1)printf("T ");
if(s123[i]==2)printf("L ");
}
printf("%.2f",max);
return 0;
}