Cet article présente principalement la méthode de réalisation du jeu concours Fried Golden Flower en PHP. Il analyse les principes de mise en œuvre et les techniques algorithmiques associées du jeu Fried Golden Flower avec des exemples auxquels les amis dans le besoin peuvent se référer. it
L'exemple de cet article décrit la méthode d'implémentation du jeu concours Golden Flower en PHP. L'analyse spécifique est la suivante :
Les programmes sont indissociables des algorithmes. L'algorithme de recherche de chemin a été évoqué plus haut. Cependant, dans le diagramme d’exemple de l’époque, le chemin facultatif était le seul. Lorsque nous choisissons un algorithme, nous entendons choisir ce chemin unique. Comment le choisir ?
Je n'entrerai pas dans les règles de comparaison des deux jeux de cartes Fried Golden Flower. Indiquez simplement quand c'est une quinte : JQK
Idée : Fried Golden Flower
1. Générez aléatoirement deux jeux de cartes. La structure de chaque jeu est
Le code est le suivant :
array( array('Spade','K'), array('Club','6'), array('Spade','J'), )
Le code est le suivant. :
array( array('Spade','K'), array('Club','6'), array('Spade','J'), )
2 . Calculez le score de chaque jeu de cartes : Chaque jeu de cartes a une taille originale (c'est-à-dire à l'exclusion de la taille des paires, des quintes, des fleurs dorées, des ors droits et des bobines) , puis
le score de chaque carte est un nombre à 2 chiffres avec moins de 2 chiffres complété par des 0 en tête, tel que « A » : 14, « 10 » : 10, « 2 » : '02 ', 'k' : 13, '7' : 07
Triez les 3 cartes selon le nombre de points (du grand au petit) pour former un nombre à 6 chiffres. Par exemple, 'A27' : 140702, '829' : 090802, 'JK8' : 131108, '2A10' : 141002
Exception, pour les paires, les chiffres de la paire doivent être placés dans les deux premiers chiffres (sera discuté plus tard) Voyez pourquoi cela est fait). Par exemple, « 779 » : 070709, « 7A7 » : 070714, « A33 » : 030314
Le score actuel est un nombre à 6 chiffres et la paire est définie sur une valeur d'origine plus 10*100000. Il s'agit désormais d'un numéro à 7 chiffres. Par exemple, « 779 » : 1070709, « 7A7 » : 1070714, « A33 » : 1030314
Pour une quinte, ajoutez 20*100000 au résultat. Par exemple '345' : 2050403, 'QKA' : 2141312, '23A' : 2140302
Pour une fleur dorée, ajoutez 30*100000 au résultat. Par exemple, « Spade K, Spade 6, Spade J » : 3131106
Parce que l'or pur est en fait la somme de la fleur d'or et de l'enfant hétéro, donc l'or pur devrait être de 50*10 000. Par exemple 'Spade 7,Spade 6,Spade 8' : 5080706
Pour une canette, ajoutez 60*100000 au résultat. Par exemple, '666' : 6060606, 'JJJ' : 6111111
3. Comparez la taille des deux cartes (utilisez les points calculés pour comparer)
C'est aussi simple que ça ! !
Le code est le suivant :
<?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,',').')'; }
Le code est le suivant :
<?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,',').')'; }
Résumé : Ce qui précède est l'intégralité du contenu de cet article, j’espère qu’il pourra aider l’apprentissage de chacun.
Recommandations associées :
PHP implémente la fonction de détection et de complétion pour la balise de fin dans les balises html
analyse php et traitement des chaînes des fichiers modèles
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!