题目描述:

扑克牌游戏大家应该都比较熟悉了,一副牌由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)输入的两手牌不会出现相等的情况。

 
输入:

输入两手牌,两手牌之间用"-"连接,每手牌的每张牌以空格分隔,"-"两边没有空格,如 4 4 4 4-joker JOKER。

输出:

输出两手牌中较大的那手,不含连接符,扑克牌顺序不变,仍以空格隔开;如果不存在比较关系则输出ERROR。

样例输入:
4 4 4 4-joker JOKER
样例输出:
joker JOKER
答案提示:

(1)除了炸弹和对王之外,其他必须同类型比较。

(2)输入已经保证合法性,不用检查输入是否是合法的牌。

(3)输入的顺子已经经过从小到大排序,因此不用再排序了。

来源: <http://career-oj.huawei.com/exam/ShowSolution?method=SolutionApp&id=2281>

下面是自己实现的代码,感觉有点繁琐。不过现在还没有想到更好的实现方法。

实现代码:

#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <map>
#include <algorithm>
using namespace std;
void setColorCard();
void getCards(const string &src,string &first, string &second);
void yingsheCards(string &src,vector<int> &result);
int compareCards(vector<int> &first,vector<int> &second);
void printError();
void diplay(vector<int> &src);
map<string,int> colorCard;
int main()
{
fstream in("data.txt");
string src,f,s;
int flag = -1;
vector<int> first,second;
//设置扑克牌的映射表
setColorCard();
getline(in,src);
getCards(src,f,s); yingsheCards(f,first);
yingsheCards(s,second);
flag = compareCards(first,second);
if (flag == 0)
{
cout<<f;
}
else if (flag == 1)
{
cout<<s;
}
cout<<endl;
return 0;
}
void diplay(vector<int> &src)
{
int i,n;
n = src.size();
for (i = 0; i < n; i++)
{
cout<<src[i]<<" ";
}
cout<<endl;
}
void printError()
{
cout<<"ERROR"<<endl;
}
void setColorCard()
{
colorCard["3"] = 3;
colorCard["4"] = 4;
colorCard["5"] = 5;
colorCard["6"] = 6;
colorCard["7"] = 7;
colorCard["8"] = 8;
colorCard["9"] = 9;
colorCard["10"]= 10;
colorCard["J"] = 11;
colorCard["Q"] = 12;
colorCard["K"] = 13;
colorCard["A"] = 14;
colorCard["2"] = 15;
colorCard["joker"] = 16;
colorCard["JOKER"] = 17;
}
void getCards(const string &src,string &first, string &second)
{
int pos;
pos = src.find('-');
if (pos == string::npos)
{
return;
}
first = src.substr(0,pos);
second= src.substr(pos+1,src.size()-pos);
}
void yingsheCards(string &src,vector<int> &result)
{
string temp;
int pos,beg,value;
int flag = 0; beg = 0;
pos = src.find(' ',beg);
while (pos != string::npos)
{
temp = src.substr(beg,pos-beg);
value= colorCard[temp];
result.push_back(value);
beg = pos+1;
pos = src.find(' ',beg);
flag = 1;
}
temp = src.substr(beg,src.size());
value= colorCard[temp];
result.push_back(value);
}
int compareCards(vector<int> &first,vector<int> &second)
{
int n1,n2; //求取两副牌的张数
n1 = first.size();
n2 = second.size(); switch (n1)
{
case 1:
switch(n2)
{
case 1:
if (first[0] > second[0])
{
return 0;
}
else
{
return 1;
}
case 2:
if ((second[0] == 16 && second[1] == 17) || (second[0] == 17)&&(second[1] == 16))
{
return 1;
}
else
{
printError();
}
break;
case 4:
return 1;
default:
printError();
break;
}
break;
case 2:
switch(n2)
{
//都是对子
case 2:
if (first[0] > second[0])
{
return 0;
}
else
{
return 1;
}
case 4:
if ((first[0] == 16 && first[1] == 17) || (first[0] == 17)&&(first[1] == 16))
{
return 0;
}
else
{
return 1;
}
default:
printError();
break;
}
break;
case 3:
switch (n2)
{
case 2:
if ((second[0] == 16 && second[1] == 17) || (second[0] == 17)&&(second[1] == 16))
{
return 1;
}
else
{
printError();
}
break;
case 3:
if (first[0] > second[0])
{
return 0;
}
else
{
return 1;
}
case 4:
return 1;
default:
printError();
break;
}
break;
case 4:
switch (n2)
{
case 2:
if ((second[0] == 16 && second[1] == 17) || (second[0] == 17)&&(second[1] == 16))
{
return 1;
}
else
{
printError();
}
break;
case 4:
if (first[0] > second[0])
{
return 0;
}
else
{
return 1;
}
default:
return 0;
}
break;
case 5:
switch (n2)
{
case 2:
if ((second[0] == 16 && second[1] == 17) || (second[0] == 17)&&(second[1] == 16))
{
return 1;
}
else
{
printError();
}
break;
case 4:
return 1;
case 5:
if (first[4] > second[4])
{
return 0;
}
else
{
return 1;
}
default:
printError();
}
break;
} return -1;
}

  

华为OJ题目:扑克牌大小的更多相关文章

  1. 华为OJ题目:刷题

    题目描述: 新入职华为的小伙伴们都有在oj上面刷题的任务,共需要刷100道初级题,45道中级题,5道高级题,其中,做出来的高级题如果超标可以当初级或者中级题,做出来的中级题如果超标可以当初级题.每天, ...

  2. OJ——华为编程题目:输入字符串括号是否匹配

    package t0815; /* * 华为编程题目:输入字符串括号是否匹配 * 若都匹配输出为0,否则为1 * 样例输入:Terminal user [name | number (1)] * 样例 ...

  3. OJ题目JAVA与C运行效率对比

    [JAVA]深深跪了,OJ题目JAVA与C运行效率对比(附带清华北大OJ内存计算的对比) 看了园友的评论之后,我也好奇清橙OJ是怎么计算内存占用的.重新测试的情况附在原文后边. ----------- ...

  4. 华为OJ:火车进站

    火车进站 给定一个正整数N代表火车数量,0<N<10,接下来输入火车入站的序列,一共N辆火车,每辆火车以数字1-9编号.要求以字典序排序输出火车出站的序列号. 输入描述: 有多组测试用例, ...

  5. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

  6. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  7. 刘汝佳黑书 pku等oj题目

    原文地址:刘汝佳黑书 pku等oj题目[转]作者:小博博Mr 一.动态规划参考资料:刘汝佳<算法艺术与信息学竞赛><算法导论> 推荐题目:http://acm.pku.edu. ...

  8. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  9. 在华为oj的两个月

    一次偶然的机会,我接触到华为oj平台(http://career-oj.huawei.com/exam/camLogin.jsp),当时的心情很是兴奋,于是立马注册开通,然后迫不及待地上去做题.刚开始 ...

随机推荐

  1. 【matlab】用matlab 保存带标记图像、图片的方法总结

    最近看了一些用matlab对图形图片进行保存的帖子和资源,关于图像保存的方法给大家分享一下这些方法是大家所使用方法的一个总结. 如今常用的方法有三种printf,imwrite,saveas下面分别介 ...

  2. UML学习笔记1

    UML概述:是一种为面向对象软件设计提供的建模语言. 构成:事物things关系relationshs图diagrams UML事物:构件事物 行为事物 分组事物 注释事物 UML关系:依赖depen ...

  3. Using python to process Big Data

    Pandas is a great lib to process BIg Data. 1) pandas.pivot_table(data,values=None,columns=None,aggfu ...

  4. javascript 中的 delete

    那么,为什么我们能删除一个对象的属性: var x = { a: 1 }; delete x.a; // true x.a; // undefined 但却不能删除一个变量: var x = 1; d ...

  5. 修改FastColoredTextBox控件完成选择

    //判断是否是中文        public bool IsChina(char c)        { bool BoolValue = false;            if (Convert ...

  6. Woodbury matrix identity

    woodbury matrix identity 2014/6/20 [转载请注明出处]http://www.cnblogs.com/mashiqi http://en.wikipedia.org/w ...

  7. JSP EL表达式 与输入有关的内置对象

    与输入有关的隐含对象有两个param和paramValues,用来取得用户的请求参数.在使用EL之前可以使用如下代码取得用户的请求参数: request.getParameter(String nam ...

  8. Linux版网易云音乐播放音乐时无限显示“网络错误”的解决办法

    安装 gstreamer0.10-plugins-good debian类系统: -plugins-good

  9. LeetCode() Repeated DNA Sequences 看的非常的过瘾!

    All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: "ACG ...

  10. (转)CVPR 2016 Visual Tracking Paper Review

    CVPR 2016 Visual Tracking Paper Review  本文摘自:http://blog.csdn.net/ben_ben_niao/article/details/52072 ...