ホームページ >バックエンド開発 >PHPチュートリアル >Zha Jinhua ゲーム PHP 実装コード サイズ コンテスト
Zha Jinhua ゲーム PHP 実装コード サイズ コンテスト
プログラムはアルゴリズムと切り離せません 前回のブログでは、実際に経路探索アルゴリズムについて説明しました。ただし、当時の例の図ではオプションのパスのみでした。アルゴリズムを選択するということは、この独自のパスを選択することを意味します。それを選択するにはどうすればよいでしょうか。
中学生の頃、午後の放課後によく道端に隠れて金の花を作ってお金を賭けていたのを今でも覚えています。今は旧正月の時期でした。私たちはよく一緒に金の花を作ってお金を賭けますが、私の運はよくなく、いつも負けてしまいます。
今日は太陽が明るく輝いています。清明節の間に遊びに行っただけなので、今日はどこにも行きませんでした。何もすることがないときに、Golden Flower の 2 つのカードの大きさを比較するプログラムを使用する方法を考えました。実際に実装してみると、いくつかの方法が非常に重要なので、書き留めておきます。
わかった、これ以上ナンセンスはやめてください。
2 つのデッキのカードを「ゴールデン フラワー」と比較するためのルールには触れません。「JQK < A23 < QKA」
アイデア: 「ゴールデン フラワー」 net/ )
1" ランダムに 2 組のカードを生成します。各デッキの構造は
[php] plaincopyprint を表示?
array( array('Spade','K'), array('Club','6'), array('Spade','J'), )2」 各デッキのカードのスコアを計算します。各デッキのカードには元のサイズがあります (つまり、ペア、ストレート、ゴールデンフラワー、ストレートゴールド、およびボビン)、そして 各カードのスコアは、「A」: 14、「10」: 10、「2」: 「02」のように、2 桁未満の先頭に 0 が埋め込まれた 2 桁の数字です。 、「k」: 13、「7」: 07 3 枚のカードをポイントの数に従って (大きい順に) 並べ替え、6 桁の数字を形成します。たとえば、「A27」: 140702、'829。 ': 090802, 'JK8': 131108, '2A10': 141002 例外。ペアの場合は、最初の 2 桁にペアの数を入力します (これが行われる理由は後で説明します)。たとえば、「779」: 070709、'7A7': 070714、'A33': 030314 現在のスコアは 6 桁の数値です。ペアを元の値に 10*100000 を加えた値に設定します。たとえば、「779」になります。 : 1070709、'7A7': 1070714、'A33': 1030314 スムーズの場合 たとえば、'345': 2050403、'QKA': 2141312、'23A': 2140302 のように、結果に 20*100000 を追加します。金華の場合、結果に 30*100000 を追加します。たとえば、「スペード K、スペード 6。、スペード J」: 3131106 ストレート ゴールドは、実際には黄金の花とストレート チャイルドの合計であるため、ストレート ゴールドです。例: 'Spade 7, Spade 6, Spade 8': 5080706
コードは次のとおりです(PHP)
[php] plaincopyprint を表示しますか?
<?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教程有兴趣的朋友有所帮助。