PHP牛牛游戏算法
<?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牛牛游戏算法的更多相关文章
- 【Nodejs】“快算24”扑克牌游戏算法
算24是一款扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过四则运算得到结果24,四张牌必须仅用一次.这是一种挺好的锻炼孩子算数能力的扑克牌游戏. 各地玩法还有点差别,有的只算1-10,其它抽出来:有 ...
- php实现 24点游戏算法
php实现 24点游戏算法 一.总结 一句话总结:把多元运算转化为两元运算,先从四个数中取出两个数进行运算,然后把运算结果和第三个数进行运算,再把结果与第四个数进行运算.在求表达式的过程中,最难处理的 ...
- 基于Lua的清除类游戏算法
最近在开发游戏,用Lua语言.习惯了其它的语言,然后对Lua的一些语法很不习惯. 比如table的元素个数的取值,比switch语句等等. 不过没有办法,还是要运用Lua来写游戏的.看来学C++还真的 ...
- 使用Xamarin开发移动应用示例——数独游戏(四)产生新游戏算法改进
项目代码可以从Github下载:https://github.com/zhenl/ZL.Shudu .代码随项目进度更新. 前面我们使用一个数组保存预制的游戏,然后随机从中抽取一个游戏作为新游戏,如果 ...
- 【Nodejs】“快算24”扑克牌游戏算法 1.02
快算24是一种挺好的锻炼孩子算数能力的扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过有限四则运算得到结果24,四张牌必须仅用一次.各地玩法还有点差别,有的只算1-10,其它抽出来:有的地方把整幅牌都 ...
- 【C/C++】例题 4-2 刽子手游戏/算法竞赛入门经典/函数和递归
[题目] 猜单词游戏. 计算机想一个单词让你猜,你每次猜一个字母. 如果单词里有那个[字母],[所有该字母会显示出来]. 如果没有那个字母,算猜错一次.[最多只能猜错六次] 猜一个已经猜过的字母也算错 ...
- VC 类泡泡龙游戏算法
#include <stdio.h> #include <malloc.h> #include <string.h> /* 1 2 1 2 2 1 2 1 2 1 ...
- 游戏算法中lua脚本详解
此外,函数本身也是一个变量,比如: dp@dp:~ % cat test.lua local mylen={} mylen.len3=function (x,y,z) return math.sqrt ...
- 【Nodejs】“快算24”扑克牌游戏算法 1.01
考虑到1.00版本需要改源码变更四个数字,这版修改了一下变成控制台输入了. 先把两个数四则运算得到结果想清楚就是C2代码,三个数就是C3,四个数就是C4.简单的代码简单,却是复杂的基础:复杂的脱胎于简 ...
随机推荐
- Android related
The build env. ensure that your computer’s BIOS is set up to support Intel’s virtualization extensio ...
- 前端 --- 5 BOM 和 DOM
一.BOM BOM(Browser Object Model)是指浏览器对象模型, 它使 JavaScript 有能力与浏览器进行“对话”. 1. window 对象 一些常用的Window方法: ( ...
- WebLogic的下载与安装
一.WebLogic的介绍 WebLogic是美国bea公司出品的一个application server,确切的说是一个基于Javaee架构的中间件,纯java开发的,最新版本WebLogic ...
- 关于java做题时需要注意的事项
1.要熟悉eclipse的使用 2.用java提交时只能有一个public class 且类名只能为Main 3.提交时不能提交包名 4.提交时要将引入的包一起提交 5.虽然java提供了很多的函数, ...
- Linux中安装python3.6和第三方库
Linux中安装python3.6和第三方库 如果本机安装了python2,尽量不要管他,使用python3运行python脚本就好,因为可能有程序依赖目前的python2环境,比如yum!!!!! ...
- JAVA AES CBC 加密 解密
AES 256 , KEY 的长度为 32字节(32*8=256bit). AES 128 , KEY 的长度为 16字节(16*8=128bit) CBC 模式需要IV, IV的值是固定写死,还是当 ...
- shell脚本大小写转换
几个方法 1.tr命令 2.sed替换 3.awk的tolower() toupper() 4.perl语言 详见 http://blog.51cto.com/wangxiaoyu/197623 L ...
- 在高并发情况nginx的作用
1 场景一:如图 在单机的情况下例如:单个tomcat 有100w条请求的时候,而默认tomcat支持的并发数量并不能达到要求,所所以单台服务器 扛不住 容易宕机,瘫痪 2 高并发的情况下要让服务器不 ...
- [UE4]Scale Box:缩放容器
一.Scale Box只能有一个子控件,再拖放一控件进去是不行的. 二.Scale Box缩放保持长宽比例 三. Scale Box.Strectching.Strectch:拉伸设置. Scale ...
- js基础系列之【原型和原型链】
声明:形成本文的出发点仅仅是个人总结记录,避免遗忘,并非详实的教程:文中引用了经过个人加工的其它作者的内容,并非原创.学海无涯 引入问题 一般我们是这样写的: (需求驱动技术,疑问驱动进步) // 构 ...