Description
Alice和Bob在玩骰子游戏,他们用三颗六面的骰子,游戏规则如下:
1.点数的优先级是1点最大,其次是6,5,4,3,2。
2.三个骰子点数相同,称为"豹子",豹子之间按点数优先级比较大小。
3.如果只有两个骰子点数相同,称为"对子",对子之间按点数优先级比较大小。
4.其他情况称为"点子",点子按点数和比较大小。
5.豹子比对子、点子大,对子比点子大,如果对子的点数优先级相同,就看剩余那个骰子的点数优先级。
现在给你Alice和Bob投掷骰子的情况,判断一下胜负情况。
Input
第一行输入一个整数K,表示游戏的次数。 以后每两行表示一个样例,第一行是Alice骰子的点数。第二行是Bob骰子的点数。
Output
如果是Alice赢,输出"Alice",如果是Bob赢,输出"Bob",否则输出"Draw"。
Sample Input
3
1 1 1
6 6 6
2 1 2
4 5 4
4 5 6
6 5 4
Sample Output
Alice
Bob
Draw
解题思路:
#include<bits/stdc++.h>
using namespace std;
//以数字大小比较优先级
int judge(int *a)
{
if(a[0] == a[1])
{
if(a[0] == a[2])
{
if(a[0] == 1)
return 100*7;
else
return 100*a[0];
}
else
{
if(a[0] == 1)
return 10*7+a[2];
else if(a[2] == 1)
return 10*a[0]+7;
else
return 10*a[0]+a[2];
}
}
else if(a[0] == a[2])
{
if(a[0] == 1)
return 10*7+a[1];
else if(a[1] == 1)
return 10*a[0]+7;
else
return 10*a[0]+a[1];
}
else if(a[1] == a[2])
{
if(a[1] == 1)
return 10*7+a[0];
else if(a[0] == 1)
return 10*a[1]+7;
else
return 10*a[1]+a[0];
}
else
return a[0]+a[1]+a[2];
}
int main()
{
int k;
cin>>k;
while(k--)
{
int a[3],b[3];
scanf("%d %d %d",&a[0],&a[1],&a[2]);
scanf("%d %d %d",&b[0],&b[1],&b[2]);
int num1=judge(a);
int num2=judge(b);
if(num1 > num2)
cout<<"Alice"<<endl;
else if(num1 < num2)
cout<<"Bob"<<endl;
else
cout<<"Draw"<<endl;
}
return 0;
}