题目描述:

扑克牌游戏大家应该都比较熟悉了,一副牌由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. 黑马程序员——OC语言 核心语法(1)

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一)点语法 点语法其实本质上还是方法调用 当使用点语法时,编译器会自动展 ...

  2. Hinet 日本数据处理流程

    ---恢复内容开始--- 推荐网站: http://ju.outofmemory.cn/entry/138571 ridnet.py 将Hinet 的cnt 数据提取为sac数据,参考网站 http: ...

  3. BaiduMap Search List

    using AnfleCrawler.Common; using HtmlClient; using System; using System.Collections.Generic; using S ...

  4. HBase with MapReduce (SummaryToFile)

    上一篇文章是实现统计hbase单元值出现的个数,并将结果存放到hbase的表中,本文是将结果存放到hdfs上.其中的map实现与前文一直,连接:http://www.cnblogs.com/ljy20 ...

  5. NSAssert的使用

    NSAssert的使用   苹果在foundation.framework中定义了这么一个宏: #define NSAssert(condition, desc, ...)   第一个参数为一个条件判 ...

  6. css3 弹框功能样式

    .message-box{ position: fixed; top: 0; right: 0; bottom: 0; left: 0; background-color: rgba(0, 0, 0, ...

  7. 说说chrome上的JS调试

    步骤:审查元素 ->source->选择js文件 ->设置断点 ->触发函数 ->进入调试点step over 到elements目录下双击某一块代码还可以立刻修改,ct ...

  8. WebDriver定位元素方法

    如果把页面上的元素看作人的话,在现实世界如何找到某人呢?方法有三: 一.通过人本身的属性,例如他的姓名,手机号,身份证号,性别,这些可区别他人的属性.在web页面上的元素也有这些属性,例如,id.na ...

  9. (实用篇)php通过会话控制实现身份验证实例

    会话控制的思想就是指能够在网站中根据一个会话跟踪用户.这里整理了详细的代码,有需要的小伙伴可以参考下. 概述 http 协议是无状态的,对于每个请求,服务端无法区分用户.PHP 会话控制就是给了用户一 ...

  10. ubuntu下mysql的常用命令,MySQL数据库的基本操作命令

    一.mysql服务操作 0.查看数据库版本 sql-> status; 1.net start mysql //启动mysql服务 2.net stop mysql //停止mysql服务  3 ...