炸金花

Time Limit:1000MS  Memory Limit:65536K

Total Submit:40 Accepted:19

Description

 炸金花是一个风靡全球的扑克游戏,喜欢玩他的人不计其数,不少人因为这个游戏发了家,而更多的人则输得倾家荡产。为了帮助赌徒们戒掉它,安徽科技学院决定派你去写一个程序,帮助赌徒们更好的认识这个游戏。 

  炸金花在这里被简化成这样一个情况:每一个人都会被随机的发到1~13中的任意三张牌,然后比较大小。比较大小的方式是这样的: 

  豹子:即三张一样的牌,同类型的豹子,数字大的更大,豹子大于任何其他情况。 

  顺子:即三张递增的连续的牌,比如(4,5,6),(1,2,3),都是顺子的话,谁的点数大则大,顺子大于对子和单张。 

  对子:即两张一样的牌带一张单牌,比如(1,1,4),(2,2,5),都是对子的话,谁的那一对大则大,如果那一对也一样,则比较单张的大小。对子大于单张。 

  单张:即三张牌不是上述的三种。单张的比较大小方式是,先比较最大的,再比较第二大的,再比较第三大的。 

  你的任务是,对于给定的牌,判断输赢

Input

多组输入,每组输入两行,第一行三个数是你的三张牌,第二行是对手的三张牌

Output

每组数据输出,若你赢输出you win,否则you lose

Sample Input

9 9 9
7 8 9

Sample Output

you win

Source

这个题只需不断的分类,但感觉自己写的这代码量还是有点多了,欢迎大家来此评论

#include <stdio.h>

void my_sort(int *x, int *y, int *z)
{
int t;
if ( *x > *y ) { t = *x; *x = *y; *y = t; }
if ( *x > *z ) { t = *x; *x = *z; *z = t; }
if ( *y > *z ) { t = *y; *y = *z; *z = t; }
} int judge_1(int *x, int *y, int *z)
{
if ( *x == *y && *y == *z )
return 1;
return 0;
} int judge_2(int *x, int *y, int *z)
{
if ( *y == *x + 1 && *y == *z -1 )
return 1;
return 0;
} int judge_3(int *x, int *y, int *z)
{
if ( *x == *y )
return *x;
else if ( *y == *z ) {
return *y;
}
return 0;
} int judge_4(int *x, int *y, int *z)
{
if ( *x == *y )
return *z;
else if ( *y == *z ) {
return *x;
}
return 0;
} void printY()
{
printf("you win\n");
} void printN()
{
printf("you lose\n");
} int main()
{
int a, b, c, x, y, z;
while ( ~scanf("%d%d%d%", &a, &b, &c) )
{
scanf("%d%d%d", &x, &y, &z);
my_sort(&a, &b, &c);
my_sort(&x, &y, &c);
if ( judge_1(&a, &b, &c) ) {
if ( judge_1(&x, &y, &z) ) {
if ( c > z ) {
printY();
}
else {
printN();
}
}
else {
printY();
}
}
else if ( judge_2(&a, &b, &c) ) {
if ( judge_2(&x, &y, &z) ) {
if ( c > z ) {
printY();
}
else {
printN();
}
}
else {
printY();
}
}
else if ( judge_3(&a, &b, &c) ) {
if ( judge_3(&x, &y, &z) ) {
if ( judge_3(&a, &b, &c) > judge_3(&x, &y, &z) ) {
printY();
}
else if ( judge_3(&a, &b, &c) < judge_3(&x, &y, &z) ) {
printN();
}
else if ( judge_4(&a, &b, &c) > judge_4(&x, &y, &z) ) {
printY();
}
else {
printN();
}
}
else {
printY();
}
}
else {
if ( c > z ) {
printY();
}
else if ( c < z ) {
printN();
}
else if ( b > y ) {
printY();
}
else if ( b < y ) {
printN();
}
else if ( a > x ) {
printY();
}
else if ( a < x ) {
printN();
}
}
} return 0;
}

akoj-1222-炸金花的更多相关文章

  1. 200行代码搞定炸金花游戏(PHP版)

    <?php/* * 游戏名称:炸金花(又名三张牌.扎金花) * 开发时间:2009.1.14 * 编 程:多菜鸟 * 来 源:http://blog.csdn.net/kingerq/archi ...

  2. XidianOJ 1044 炸金花

    题目描述 炸金花是一个风靡全球的扑克游戏,不少人因为这个游戏发了家,而更多的人则输得倾家荡产.为了帮助赌徒们戒掉它,现在决定派你去写一个程序,帮助赌徒们更好的认识这个游戏. 炸金花在这里被简化成这样一 ...

  3. 炸金花的JS实现从0开始之 -------现在什么都不会(1)

    新年结束了.回想起来唯一留下乐趣的就是在家和朋友玩玩炸金花. 遂有此文. 对不起,我这时候还没有思路. 让我捋一捋. ... ... 捋一捋啊... ... 好了.今天先这样吧: (1)先整理出所有的 ...

  4. 炸金花游戏(4)--炸金花AI基准测试评估

    前言: 本文将谈谈如何评估测试炸金花的AI, 其实这个也代表一类的问题, 德州扑克也是类似的解法. 本文将谈谈两种思路, 一种是基于基准AI对抗评估, 另一种是基于测试集(人工选定牌谱). 由于炸金花 ...

  5. 炸金花游戏(3)--基于EV(期望收益)的简单AI模型

    前言: 炸金花这款游戏, 从技术的角度来说, 比德州差了很多. 所以他的AI模型也相对简单一些. 本文从EV(期望收益)的角度, 来尝试构建一个简单的炸金花AI. 相关文章: 德州扑克AI--Prog ...

  6. 品鉴同事发来的炸金花的PHP程序代码

    今天同事发来了一个炸金花的PHP程序,这个代码实现了两个人通过各自的三张牌进行权重计算,得到分数进行比较得到谁的牌大,我觉得里面还有一些问题,代码如下: <?php /** 每张牌的分值为一个2 ...

  7. 自己写的微信小程序炸金花简单版

    app.json: { "pages":[ "pages/index/index" ], "window":{ "navigati ...

  8. IOS本地化。

    1,项目名本地化 点击项目,蓝色图标->info 最下面+号,添加chinese本地化. Supporting Files->infoPlist.strings 下会有两个文件,有一个是设 ...

  9. 【Android病毒分析报告】 - ZxtdPay 吸费恶魔

    本文章由Jack_Jia编写,转载请注明出处.  文章链接:http://blog.csdn.net/jiazhijun/article/details/11581543 作者:Jack_Jia    ...

随机推荐

  1. Mathematica学习笔记2

    导入文件中的矩阵 mat = Import["...", "Table"] 转化为向量矩阵(元素为数对) data = Table[{mat[[i, j]], ...

  2. Django+MySQL开发项目:内容管理系统cms(一)

    Baker-Miller Pink被科学方法证实可以平静情绪并且抑制食欲的颜色,具有amazing的效果.基百里面说实验结果表明该颜色具有: "a marked effect on lowe ...

  3. 收集了一些容易出错的题,可能大家也不会注意到的基础知识(js)

    ---恢复内容开始--- 1.题中运用到函数表达式.构造函数.原型.优先级.this. 2.参数影响 3.对原型的运用 4.递归 5.基本类型与引用类型传递 6.优先级 7.自调用函数 ---恢复内容 ...

  4. 第二章:1.0 Django 入门和开发环境

    1. 选择 Django Web框架来做Web接口开发,主要原因是由于学习资料丰富,便于学习. 2. Django 对 python 版本的支持情况. Django 的版本在 1.8 ,1.9 , 1 ...

  5. java基础之集合框架(1)

    一.介绍Collection 1.概念:Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements).一些Collection ...

  6. poj3320 (尺取法)

    n个数,求最小区间覆盖着n个数中所有的不相同的数字. 解题思路: AC代码: import java.util.HashMap; import java.util.HashSet; import ja ...

  7. MySql单表最大8000W+ 之数据库遇瓶颈记

    前言 昨晚救火到两三点,早上七点多醒来,朦胧中醒来发现电脑还开着,赶紧爬起来看昨晚执行的SQL命令结果.由于昨晚升级了阿里云的RDS,等了将近两个小时 还在 升降级中,早上阿里云那边回复升级过程中出现 ...

  8. JS事件响应的学习总结

    点击事件:ocnlick 鼠标经过事件:onmouseover 鼠标移开事件:onmouseout 获得焦点事件:onfocus 失去焦点事件:onblur 内容选中事件:onselect 文本框内容 ...

  9. 程序员必知的Python陷阱与缺陷列表

    本文关注的主要是python陷阱,具体而言,是指CPython,而且除非特别说明,所有代码示例都是在python2.7运行的. 我个人对陷阱的定义是这样的:代码看起来可以工作,但不是以你“想当然“”的 ...

  10. POJ 2289 Jamie's Contact Groups / UVA 1345 Jamie's Contact Groups / ZOJ 2399 Jamie's Contact Groups / HDU 1699 Jamie's Contact Groups / SCU 1996 Jamie's Contact Groups (二分,二分图匹配)

    POJ 2289 Jamie's Contact Groups / UVA 1345 Jamie's Contact Groups / ZOJ 2399 Jamie's Contact Groups ...