现在有一种牌的玩法如下:共36张牌,牌点为2-10,每样4张。两个人玩,每人从所有牌中取两张,然后比较大小,大的方获胜。
比较大小规则如下。 1、两张牌的总牌点值为两张牌的各自牌点值相加后除以10的余数,如一张5一张6,则总牌点为1; 2、比较大小时,比较的是总牌点儿。也就是说总牌点大的一方获胜; 3、当总牌点相等时,则看牌点最大的单张,牌点大的获胜。如一张3一张6胜过一张4一张5; 4、如果两张牌的牌点相等(对子),则不计总牌点,它们一定胜过所有非对子的组合; 5、对子和对子比较,按单张牌点比大小,如对8胜过对7。 6、如果两个人的牌完全一样,则是平局。
现请你写一段程序来判断两个玩家的胜负。
输入格式:
只有一行,为4个字符,前两个代表A的牌,后两个代表B的牌(字符’T’,代表10)。
输出格式:
只有一行,先输出获胜者(两人的牌完全一样时,按A胜输出),然后是一个冒号,最后是牌面(如果是对子,则输出代表单张牌的字符,否则输出总牌点数)。
测试用例保证输入合法。
输入样例一:
3645
输出样例一:
A:9
输入样例二:
85T3
输出样例二:
B:3
输入样例三:
3455
输出样例三:
B:5
#include<stdio.h>
int main()
{
int max(int a,int b);
char a[4];
int i=0;
for(i=0;i<4;i++)
{
scanf("%c",&a[i]);
if(a[i]=='T')
a[i]=':';
}
int e,b,c,d;
e=a[0]-'0';
b=a[1]-'0';
c=a[2]-'0';
d=a[3]-'0';
if(e==b)
{
if(c!=d)
printf("A:%d",e);
else
{
if(e>=c)
{if (e==10)
printf("A:T");
else
printf("A:%d",e);}
else
{if (c==10)
printf("B:T");
else
printf("B:%d",c);}
}
}
else if(c==d)
{if (c==10)
printf("B:T");
else
printf("B:%d",c);}
else if((e+b)%10>(c+d)%10)
printf("A:%d",(e+b)%10);
else if((e+b)%10<(c+d)%10)
printf("B:%d",(c+d)%10);
else if((e+b)%10==(c+d)%10)
{
if(max(e,b)>=max(c,d))
printf("A:%d",(e+b)%10);
else
printf("B:%d",(c+d)%10);
}
return 0;
}
int max(int a,int b)
{
int x;
if(a>=b)
x=a;
else
x=b;
return x;
}