<?php

namespace frontend\business;

class NiuNiuGameHelper
{ /**
* @param $card
* @return int 结果 -1 每牛; 0 牛牛; 1 - 9 牛一 到 牛九
*/
public static function JudgeCowCow($card)
{
if(!is_array($card) || count($card) !== 5)
{
return -1;
}
$cow = -1;
//计算5张牌总值,cow计算牛几。
$cardall = 0;
$n=0;//存储10、J、Q、K张数。 for($i=0;$i<4;$i++)//对5张牌从大到小排序。
{
for($j=$i+1;$j<5;$j++)
if($card[$i] < $card[$j])
{
$a = $card[$i];
$card[$i] = $card[$j];
$card[$j]=$a;
}
}
for($i=0;$i<5;$i++)
{
if($card[$i] >= 10)
{
$n++;
$card[$i] = 10;
}
$cardall += $card[$i];
}
//10 10 6 5 3 牛牛时5张牌总和肯定是10的倍数,五张牌总和是10的倍数未必是牛牛,下面代码不成立
//if(cardall %10 == 0)
//{
// print(0);//牛牛
// exit(0);
//}
switch ($n)
{
case 0: //5张牌中没有一张10、J、Q、K。
{
for($i=0;$i<4;$i++)
{
for($j=$i + 1;$j<5;$j++)
if(($cardall - $card[$i]- $card[$j])%10==0)
{
$cow=($card[$i] + $card[$j])%10;
return $cow;
}
}
break;
}
case 1: //5张牌中有一张10、J、Q、K。
{
//先判断是否有牛牛,不能判断剩余四张相加为10倍数为牛牛,如 Q 8 5 4 3
//只能先判断两张是否是10的倍数,如果是再判断剩余是否是10的倍数;有限判断出牛牛;再来判断三张是否有10的倍数,有的话有牛,否则无牛
for($i =1; $i < 4; $i ++)
{
for($j = $i +1; $j < 5; $j++)
{
if(($card[$i] + $card[$j]) % 10 == 0)
{
$cow=($cardall - $card[0])%10;
return $cow;
}
}
}
//判断是否有牛
for($i=1; $i<5; $i++) //剩下四张牌有三张加起来等于10
{
if(($cardall - $card[0] - $card[$i])%10==0)
{
$cow=($cardall-$card[0])%10;
break;
}
}
break;
}
case 2: //5张牌中有两张10、J、Q、K。 三张是个牛就有问题,应该优先输出
{ if(($cardall - $card[0] - $card[1])%10 == 0)//优先牛牛输出 如 J Q 2 3 5;这里先检查剩余是否为牛牛,否则算法有漏洞
{
$cow = 0;
}
else
{
//10 10 6 5 3 n=2 i=3 j=4 cardall = 34
for($i=$n;$i<4;$i++)//剩下三(四)张牌有两张加起来等于10。
{
for($j=$i+1;$j<5;$j++)
{
if(($card[$i]+$card[$j])==10)
{
$temp = $cardall;
for($k=0;$k<$n;$k++)//总值减去10、J、Q、K的牌。
$temp -= $card[$k]; //
$cow = $temp%10; //
}
}
/*print_r('cardall:'.$cardall);
print_r("<br />");
print_r('cow'.$cow);
print_r("<br />");*/
} }
break;
} case 3: //5张牌中有三张10、J、Q、K。
case 4: //5张牌中有四张10、J、Q、K。
case 5: //5张牌中五张都是10、J、Q、K。
{
for($i=0;$i<$n;$i++)//总值减去10、J、Q、K的牌。
{
$cardall -= $card[$i];
}
$cow = $cardall%10;
break;
} } return $cow;
}
}

PHP牛牛游戏算法的更多相关文章

  1. 【Nodejs】“快算24”扑克牌游戏算法

    算24是一款扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过四则运算得到结果24,四张牌必须仅用一次.这是一种挺好的锻炼孩子算数能力的扑克牌游戏. 各地玩法还有点差别,有的只算1-10,其它抽出来:有 ...

  2. php实现 24点游戏算法

    php实现 24点游戏算法 一.总结 一句话总结:把多元运算转化为两元运算,先从四个数中取出两个数进行运算,然后把运算结果和第三个数进行运算,再把结果与第四个数进行运算.在求表达式的过程中,最难处理的 ...

  3. 基于Lua的清除类游戏算法

    最近在开发游戏,用Lua语言.习惯了其它的语言,然后对Lua的一些语法很不习惯. 比如table的元素个数的取值,比switch语句等等. 不过没有办法,还是要运用Lua来写游戏的.看来学C++还真的 ...

  4. 使用Xamarin开发移动应用示例——数独游戏(四)产生新游戏算法改进

    项目代码可以从Github下载:https://github.com/zhenl/ZL.Shudu .代码随项目进度更新. 前面我们使用一个数组保存预制的游戏,然后随机从中抽取一个游戏作为新游戏,如果 ...

  5. 【Nodejs】“快算24”扑克牌游戏算法 1.02

    快算24是一种挺好的锻炼孩子算数能力的扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过有限四则运算得到结果24,四张牌必须仅用一次.各地玩法还有点差别,有的只算1-10,其它抽出来:有的地方把整幅牌都 ...

  6. 【C/C++】例题 4-2 刽子手游戏/算法竞赛入门经典/函数和递归

    [题目] 猜单词游戏. 计算机想一个单词让你猜,你每次猜一个字母. 如果单词里有那个[字母],[所有该字母会显示出来]. 如果没有那个字母,算猜错一次.[最多只能猜错六次] 猜一个已经猜过的字母也算错 ...

  7. VC 类泡泡龙游戏算法

    #include <stdio.h> #include <malloc.h> #include <string.h> /* 1 2 1 2 2 1 2 1 2 1 ...

  8. 游戏算法中lua脚本详解

    此外,函数本身也是一个变量,比如: dp@dp:~ % cat test.lua local mylen={} mylen.len3=function (x,y,z) return math.sqrt ...

  9. 【Nodejs】“快算24”扑克牌游戏算法 1.01

    考虑到1.00版本需要改源码变更四个数字,这版修改了一下变成控制台输入了. 先把两个数四则运算得到结果想清楚就是C2代码,三个数就是C3,四个数就是C4.简单的代码简单,却是复杂的基础:复杂的脱胎于简 ...

随机推荐

  1. robot framework浏览器与驱动的匹配

    一.谷歌浏览器和火狐浏览器与驱动不匹配产生的问题 1.若在运行过程中出现[Unable to find a matching set of capabilities ][ WebDriverExcep ...

  2. HTTP 各状态码大全

    基本涵盖了所有问题 HTTP 400 – 请求无效 HTTP 401.1 – 未授权:登录失败 HTTP 401.2 – 未授权:服务器配置问题导致登录失败 HTTP 401.3 – ACL 禁止访问 ...

  3. python魔法方法

    1.__call__ 实现__call__后,该类的对象可以被调用 举例如: class test_call_: def __init__(self, n): self.n = n def __cal ...

  4. POJ3017 Cut the Sequence

    题意 Language:Default Cut the Sequence Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 122 ...

  5. Property referenced in indexed property path is neither an array nor a List nor a Map

    记一次传参请求报错,没有解决 Invalid property 'distributeCars[0][ackStatus]' of bean class [com.api6.plate.prototy ...

  6. oracle中如何修改用户名和密码

    1.以Windows操作系统为例,打开命令提示符,输入命令sqlplus /nolog ,进入oracle控制台,并输入 conn /as sysdba;以DBA角色进入. 2.连接成功后,输入“se ...

  7. [转]Java事件处理机制- 事件监听器的四种实现方式

    原文来自http://stefan321.iteye.com/blog/345221 自身类作为事件监听器 外部类作为事件监听器 匿名内部类作为事件监听器 内部类作为事件监听器 自身类作为事件监听器: ...

  8. Angular2中使用ngx-translate进行国际化

    转自 https://blog.csdn.net/u014291497/article/details/61233033 相较于angularjs中的ng-translate, angular2也有适 ...

  9. 高性能mysql 第六章查询性能优化 总结(上)查询的执行过程

    6  查询性能优化 6.1为什么查询会变慢 这里说明了的查询执行周期,从客户端到服务器端,服务器端解析,优化器生成执行计划,执行(可以细分,大体过程可以通过show profile查看),从服务器端返 ...

  10. 涂抹mysql笔记-数据导出导入

    数据导出导入<>利用CSV存储引擎加载数据:CSV存储引擎基于CSV格式文件存储数据,CSV格式是纯文本格式的文件,以逗号分隔取值.CSV引擎表的所有列值不能为空.Excel可以直接打开有 ...