题目描述
扑克牌游戏大家应该都比较熟悉了,一副牌由54张组成,含3~A,2各4张,小王1张,大王1张。牌面从小到大用如下字符和字符串表示(其中,小写joker表示小王,大写JOKER表示大王):)
3 4 5 6 7 8 9 10 J Q K A 2 joker JOKER
输入两手牌,两手牌之间用“-”连接,每手牌的每张牌以空格分隔,“-”两边没有空格,如:4 4 4 4-joker JOKER
请比较两手牌大小,输出较大的牌,如果不存在比较关系则输出ERROR
基本规则: (1)输入每手牌可能是个子,对子,顺子(连续5张),三个,炸弹(四个)和对王中的一种,不存在其他情况,由输入保证两手牌都是合法的,顺子已经从小到大排列;
(2)除了炸弹和对王可以和所有牌比较之外,其他类型的牌只能跟相同类型的存在比较关系(如,对子跟对子比较,三个跟三个比较),不考虑拆牌情况(如:将对子拆分成个子)
(3)大小规则跟大家平时了解的常见规则相同,个子,对子,三个比较牌面大小;顺子比较最小牌大小;炸弹大于前面所有的牌,炸弹之间比较牌面大小;对王是最大的牌;
(4)输入的两手牌不会出现相等的情况。
答案提示:
(1)除了炸弹和对王之外,其他必须同类型比较。
(2)输入已经保证合法性,不用检查输入是否是合法的牌。
(3)输入的顺子已经经过从小到大排序,因此不用再排序了。
输入描述
输入两手牌,两手牌之间用“-”连接,每手牌的每张牌以空格分隔,“-”两边没有空格,如4 4 4 4-joker JOKER。
输出描述
输出两手牌中较大的那手,不含连接符,扑克牌顺序不变,仍以空格隔开;如果不存在比较关系则输出ERROR。
输入例子:
4 4 4 4-joker JOKER
输出例子:
joker JOKER
程序代码
#include <iostream>
#include <stdio.h>
#include <string>
#include <vector>
using namespace std;
int SumNum(string str){ //统计牌的个数
int len=str.length();
int sum=0;
for(int i=0;i<len;i++){
if(str[i]!=' '){
if(str[i]=='1'){ //判断是否为10
i++;
}
sum++;
}
}
return sum;
}
int ComPare(char c){
if(c=='3')
return 3;
else if(c=='4')
return 4;
else if(c=='5')
return 5;
else if(c=='6')
return 6;
else if(c=='7')
return 7;
else if(c=='8')
return 8;
else if(c=='9')
return 9;
else if(c=='1')
return 10;
else if(c=='J')
return 11;
else if(c=='Q')
return 12;
else if(c=='K')
return 13;
else if(c=='A')
return 14;
else
return 15;
}
int main(){
string inputstr;
getline(cin,inputstr);
int count=0;
while(inputstr[count]!='-'){ //定位字符-
count++;
}
string leftpai,rightpai;
for(int i=0;i<count;i++) //分割左手牌
leftpai=leftpai+inputstr[i];
int len=inputstr.length();
for(int i=count+1;i<len;i++){ //分割右手牌
rightpai=rightpai+inputstr[i];
}
int leftlen=SumNum(leftpai);
int rightlen=SumNum(rightpai);
if(leftlen!=rightlen){
if(leftlen==10||rightlen==10){
cout<<"joker JOKER"<<endl;
}else if(leftlen==4){
cout<<leftpai<<endl;
}else if(rightlen==4){
cout<<rightpai<<endl;
}else{
cout<<"ERROR"<<endl;
}
}else{
if(ComPare(leftpai[0])>ComPare(rightpai[0]))
cout<<leftpai<<endl;
else
cout<<rightpai<<endl;
}
system("pause");
}