1011 世界杯博彩
随着2020国际足联世界杯的举行,全世界最好的球队中最棒的球员都在为了世界杯奖杯而在南美拼搏,因此来自世界各地的球迷非常激动和兴奋。同样的,爱好足球赌博的人也通过实际行动参与了进来,不过用的是各种世界杯赌博方式。
中国足球彩票推出了一个“三倍赢”游戏。胜利的规则非常简单:首先为三局游戏选择可能的结果。即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.13.02.5*65%-1)*2= 37.98元。(精确到两位小数)
输入规范
每个输入文件包含一个测试实例。每个实例包含三局游戏的赌博信息。每个游戏有一行,里面包含三个与W、T和L对应的赔率。
输出规范
对于每个测试实例,在一行中输出每局游戏的最好的赌博选择,最大利润精确到两位小数。字符和数字必须用一个空格分隔。
输入样例
1.1 2.5 1.7
1.2 3.1 1.6
4.1 1.2 1.1
输出样例
T T W 39.31
解题思路
这道题翻译是真的难,只需要关注(4.1*3.0*2.5*65%-1)*2= 37.98
这个计算式,然后猜一猜其中需要用到的数字即可。如果将变量设为X,Y,Z的话,那么一般计算式就是(X*Y*Z*0.65 - 1) * 2
。其中X,Y,Z就是三行每一行的最大值。
AC代码
#include <iostream>
#include <algorithm>
#include <cstdio>
using namespace std;
double value[3][3];
int main() {
string ch = "WTL";
pair<double, char> res[3];
for(int i = 0; i < 3; i++) {
double t = -1;
for(int j = 0; j < 3; j++) {
cin >> value[i][j];
if(t < value[i][j]) {
t = value[i][j];
res[i] = make_pair(value[i][j], ch[j]);
}
}
}
double sum = (res[0].first * res[1].first * res[2].first * 0.65 - 1) * 2;
for(int i = 0; i < 3; i++) {
cout << res[i].second << ' ';
}
printf("%.2lf\n", sum);
return 0;
}