PHP implémente un concours de jeux de fleurs d'or
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

Se connecter à CakePHP est une tâche très simple. Il vous suffit d'utiliser une seule fonction. Vous pouvez enregistrer les erreurs, les exceptions, les activités des utilisateurs, les actions entreprises par les utilisateurs, pour tout processus en arrière-plan comme cronjob. La journalisation des données dans CakePHP est facile. La fonction log() est fournie

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.
