扑克牌大小(华为16年研发试题)
来源:互联网 发布:淘宝售假申诉流程 编辑:程序博客网 时间:2024/05/18 01:18
[编程题] 扑克牌大小
扑克牌游戏大家应该都比较熟悉了,一副牌由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
存在问题:对于输入中含有10的失效,因为它包含两个字符,这里没有进行判断。也可以将所有的数都转为十进制存到数组中进行判断,有空再更新。
#include<iostream>#include<string>using namespace std;int main(){int left=0,right=0;//记录左右手牌的个数;int mid;//记录中间位置;;string str;//输入的字符串;int flag=0;getline(cin,str);int len=str.size();for (int i=0;i<len;i++){if (str[i]==' '&&flag==0){left++;//判断左边字符个数;}if(str[i]=='-'){flag=1;mid=i;}if (str[i]==' '&&flag==1){right++;}}left++;right++;if (left==1)//左手的牌数为一;{if (left==right){if (str[0]<str[2]){cout<<str[2]<<endl;}else{cout<<(str[0])<<endl;}}else if(right==4||right==2)//炸弹或者对王;{for(int m=mid+1;m<len;m++)cout<<str[m];}else{cout<<"ERROR"<<endl;}}if (left==2)//左手的牌数为二;{if (str[0]=='j')//左手为对王;{for(int m=0;m<mid;m++)cout<<str[m];return 0;}if (left==right){if (str[0]<str[4]||str[4]=='j')//右手的牌大;{for(int m=mid+1;m<len;m++)cout<<str[m];}}else if(right==4)//炸弹或者对王;{for(int m=mid+1;m<len;m++)cout<<str[m];}else{cout<<"ERROR"<<endl;}}if (left==3)//左手的牌数为三;{if (left==right){if (str[0]<str[6]){for(int m=mid+1;m<len;m++)cout<<str[m];}else{for(int m=0;m<mid;m++)cout<<str[m];}}else if(right==4||right==2)//炸弹或者对王;{for(int m=mid+1;m<len;m++)cout<<str[m];}else{cout<<"ERROR"<<endl;}}if (left==4){if (left==right){if (str[0]<str[8]){for(int m=mid+1;m<len;m++)cout<<str[m];}else{for(int m=0;m<mid;m++)cout<<str[m];}}else if(right==2&&str[8]=='j')//对王;{for(int m=mid+1;m<len;m++)cout<<str[m];}else {for(int m=0;m<mid;m++)cout<<str[m];}}if (left==5){if (left==right){if (str[0]<str[10]){for(int m=mid+1;m<len;m++)cout<<str[m];}else{for(int m=0;m<mid;m++)cout<<str[m];}}else if(right==4||(right==2&&str[10]=='j'))//炸弹或者对王;{for(int m=mid+1;m<len;m++)cout<<str[m];}else{cout<<"ERROR"<<endl;}}cout<<endl;system("pause");}
- 扑克牌大小(华为16年研发试题)
- 最高分是多少(华为16年研发试题)
- 华为oj 扑克牌大小
- 华为OJ 扑克牌大小
- 华为面试题:扑克牌大小 C语言源码
- 【华为OJ】【103-扑克牌大小】
- [华为机试]扑克牌大小
- 华为机试---扑克牌大小
- 华为OJ—扑克牌大小
- 华为oj 扑克牌的大小
- 华为笔试_扑克牌大小
- 牛客网---2016---华为扑克牌大小
- 简单错误记录(华为16年研发试题)
- 华为OJ——扑克牌大小
- 华为机试—扑克牌比大小
- 扑克牌大小(华为2016校招)
- 华为OJ——扑克牌大小
- 华为OJ——扑克牌大小
- 【公告】C币系统升级,会议系统升级
- Tmux使用初体验
- unity中实现A*算法的一些问题
- rqnoj 389 心灵的抚慰 (floyd求解环的最小权值)
- HDU 1061 Rightmost Digit(快速幂)
- 扑克牌大小(华为16年研发试题)
- Eclipse插件开发GEF
- 给listView添加headView或footView不显示的问题
- HttpURLConnection与HttpClient区别及联系
- laravel框架的使用1---路由
- opengl es2 创建两个三角形
- 欢迎使用CSDN-markdown编辑器
- php-进度条 ob_flush() 的使用
- BZOJ 2503 相框 并查集