0

0

扎金花游戏 PHP 实现代码之大小比赛

php中文网

php中文网

发布时间:2016-08-08 09:28:45

|

1248人浏览过

|

来源于php中文网

原创

扎金花游戏 PHP 实现代码之大小比赛

程序离不开算法,在前面的博客当中,其实我们已经讨论过寻路的算法。不过,当时的示例图中,可选的路径是唯一的。我们挑选一个算法,就是说要把这个唯一的路径选出来,怎么选呢?

还记得上初中的时候经常下午放学就躲在路边扎金花来赌*钱,貌似还上瘾了,现在过年的时候还经常一起扎金花赌*钱,但运气不啥好,每次都是输啊。

今天阳光明媚,由于清明节才出去玩了,所以今天没有去哪。闲着没事就想了下怎么用程序实现金花中两幅牌的大小比较,现在把它实现了,有些方法还是蛮重要的,因此就记下来。

好了,不废话了。

扎金花两副牌的比较规则就不说了,注明一下是顺子的时候 : JQK

立即学习PHP免费学习笔记(深入)”;

思路:扎金花(http://www.a8u.net/)

1" 随机生成两幅牌,每副牌结构为

[php] view plaincopyprint?

  1. array(  
  2.     array('Spade','K'),  
  3.     array('Club','6'),  
  4.     array('Spade','J'),  
  5. )  
array(
    array('Spade','K'),
    array('Club','6'),
    array('Spade','J'),
)

2” 计算每副牌的分值:每副牌有个原始大小(即排除对子,顺子,金花,顺金,筒子的大小),再

    每张牌的分值为一个2位数,不足2位的补前导0,例如'A':14,‘10’:10,’2‘:’02‘,’k‘:13,’7‘:07

    将3张牌按点数大小排序(从大到小),凑成一个6位数。例如’A27':140702,‘829’:090802,‘JK8’:131108,‘2A10’:141002

影谱
影谱

汉语电影AI辅助创作平台

下载

    例外,对于对子要将对子的位数放在前两位(后面会看到为什么这么做)。例如‘779’:070709,‘7A7’:070714,‘A33’:030314

   现在的分值是一个6位数,将对子设为一个原始值加上10*100000的值,现在为一个7位数。例如‘779’:1070709,‘7A7’:1070714,‘A33’:1030314

   对于顺子,将结果加上20*100000.。例如‘345’:2050403,‘QKA’:2141312,‘23A’:2140302

   对于金花,将结果加上30*100000。例如‘Spade K,Spade 6,Spade J':3131106

   因为顺金的时候其实是金花和顺子的和,所以顺金应该是50*10000。 例如‘Spade 7,Spade 6,Spade 8':5080706

   对于筒子,将结果加上60*100000。例如’666‘:6060606,’JJJ‘:6111111

3“ 比较两幅牌的大小(用所计算的分值来比较)

就这么简单!!

代码如下(PHP)

[php] view plaincopyprint?

  1. class PlayCards  
  2. {  
  3.     public $suits = array('Spade''Heart''Diamond''Club');  
  4.     public $figures = array('2''3''4''5''6''7''8''9''10''J''Q''K''A');  
  5.     public $cards = array();  
  6.     public function __construct()  
  7.     {  
  8.         $cards = array();  
  9.         foreach($this->suits as $suit){  
  10.             foreach($this->figures as $figure){  
  11.                 $cards[] = array($suit,$figure);  
  12.             }  
  13.         }  
  14.         $this->cards = $cards;  
  15.     }  
  16.     public function getCard()  
  17.     {  
  18.         shuffle($this->cards);  
  19.         //生成3张牌  
  20.         return array(array_pop($this->cards), array_pop($this->cards), array_pop($this->cards));     
  21.   
  22.     }  
  23.     public function compareCards($card1,$card2)  
  24.     {  
  25.         $score1 = $this->ownScore($card1);  
  26.         $score2 = $this->ownScore($card2);  
  27.         if($score1 > $score2return 1;  
  28.         elseif($score1 $score2return -1;  
  29.         return 0;         
  30.     }  
  31.       
  32.       
  33.     private function ownScore($card)  
  34.     {  
  35.         $suit = $figure = array();  
  36.         foreach($card as $v){  
  37.             $suit[] = $v[0];  
  38.             $figure[] = array_search($v[1],$this->figures)+2;  
  39.         }  
  40.         //补齐前导0  
  41.         for($i = 0; $i $i++){  
  42.             $figure[$i] = str_pad($figure[$i],2,'0',STR_PAD_LEFT);  
  43.         }  
  44.         rsort($figure);  
  45.         //对于对子做特殊处理  
  46.         if($figure[1] == $figure[2]){  
  47.             $temp = $figure[0];  
  48.             $figure[0] = $figure[2];  
  49.             $figure[2] = $temp;  
  50.         }  
  51.         $score = $figure[0].$figure[1].$figure[2];  
  52.         //筒子 60*100000  
  53.         if($figure[0] == $figure[1] && $figure[0] == $figure[2]){  
  54.             $score += 60*100000;  
  55.         }  
  56.         //金花 30*100000  
  57.         if($suit[0] == $suit[1] && $suit[0] == $suit[2]){  
  58.             $score += 30*100000;  
  59.         }  
  60.         //顺子 20*100000  
  61.         if($figure[0] == $figure[1]+1 && $figure[1] == $figure[2]+1 || implode($figure) =='140302'){  
  62.             $score += 20*100000;  
  63.         }  
  64.         //对子 10*100000  
  65.         if($figure[0] == $figure[1] && $figure[1] != $figure[2]){  
  66.   
  67.             $score += 10*100000;  
  68.         }  
  69.         return $score;  
  70.     }  
  71. }  
  72.   
  73. //test  
  74. $playCard = new PlayCards();  
  75. $card1 = $playCard->getCard();  
  76. $card2 = $playCard->getCard();  
  77. $result = $playCard->compareCards($card1,$card2);  
  78.   
  79. echo 'card1 is ',printCard($card1),'
    '
    ;  
  80. echo 'card2 is ',printCard($card2),'
    '
    ;  
  81. $str = 'card1 equit card2';  
  82. if($result == 1) $str =  'card1 is larger than card2';  
  83. elseif($result == -1) $str = 'card1 is smaller than card2';  
  84. echo $str;  
  85.   
  86.   
  87. function printCard($card)  
  88. {  
  89.     $str = '(';  
  90.     foreach($card as $v){  
  91.         $str .= $v[0].$v[1].',';  
  92.     }  
  93.     return trim($str,',').')';  
  94. }  
<?php
class PlayCards
{
	public $suits = array('Spade', 'Heart', 'Diamond', 'Club');
	public $figures = array('2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K', 'A');
	public $cards = array();
	public function __construct()
	{
		$cards = array();
		foreach($this->suits as $suit){
			foreach($this->figures as $figure){
				$cards[] = array($suit,$figure);
			}
		}
		$this->cards = $cards;
	}
	public function getCard()
	{
		shuffle($this->cards);
		//生成3张牌
		return array(array_pop($this->cards), array_pop($this->cards), array_pop($this->cards));	

	}
	public function compareCards($card1,$card2)
	{
		$score1 = $this->ownScore($card1);
		$score2 = $this->ownScore($card2);
		if($score1 > $score2) return 1;
		elseif($score1 < $score2) return -1;
		return 0;		
	}
	
	
	private function ownScore($card)
	{
		$suit = $figure = array();
		foreach($card as $v){
			$suit[] = $v[0];
			$figure[] = array_search($v[1],$this->figures)+2;
		}
		//补齐前导0
		for($i = 0; $i < 3; $i++){
			$figure[$i] = str_pad($figure[$i],2,'0',STR_PAD_LEFT);
		}
		rsort($figure);
		//对于对子做特殊处理
		if($figure[1] == $figure[2]){
			$temp = $figure[0];
			$figure[0] = $figure[2];
			$figure[2] = $temp;
		}
		$score = $figure[0].$figure[1].$figure[2];
		//筒子 60*100000
		if($figure[0] == $figure[1] && $figure[0] == $figure[2]){
			$score += 60*100000;
		}
		//金花 30*100000
		if($suit[0] == $suit[1] && $suit[0] == $suit[2]){
			$score += 30*100000;
		}
		//顺子 20*100000
		if($figure[0] == $figure[1]+1 && $figure[1] == $figure[2]+1 || implode($figure) =='140302'){
			$score += 20*100000;
		}
		//对子 10*100000
		if($figure[0] == $figure[1] && $figure[1] != $figure[2]){

			$score += 10*100000;
		}
		return $score;
	}
}

//test
$playCard = new PlayCards();
$card1 = $playCard->getCard();
$card2 = $playCard->getCard();
$result = $playCard->compareCards($card1,$card2);

echo 'card1 is ',printCard($card1),'<br/>';
echo 'card2 is ',printCard($card2),'<br/>';
$str = 'card1 equit card2';
if($result == 1) $str =  'card1 is larger than card2';
elseif($result == -1) $str = 'card1 is smaller than card2';
echo $str;


function printCard($card)
{
	$str = '(';
	foreach($card as $v){
		$str .= $v[0].$v[1].',';
	}
	return trim($str,',').')';
}

以上就介绍了扎金花游戏 PHP 实现代码之大小比赛,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关文章

在线游戏
在线游戏

海量精品小游戏合集,无需安装即点即玩,休闲益智、动作闯关应有尽有,秒开即玩,轻松解压,快乐停不下来

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

616

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

194

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

91

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

20

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

54

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

598

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

56

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP函数之array数组函数视频讲解
PHP函数之array数组函数视频讲解

共76课时 | 26.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号