Implementieren Sie ein einfaches Pokerspiel mit Java
Poker-Minispiel:
(Empfohlenes Tutorial: Java-Kurs)
Einführung in das Spiel: Definieren Sie fünf Personen, die ein Pokerspiel spielen. Das Gameplay besteht darin, dass 5 Personen aus einem Kartenspiel ohne König auswählen oder König. Es werden jeweils 4 Karten gezogen, und es gibt vier Kartentypen: ♥, ♣, ♠ und ♦. Die Größe der Karten reicht von 1 bis 13. (Der Einfachheit halber werden hier nur 1-5 genommen).
1. Welcher Spieler auch immer das Pik-♠A auf der Hand hat, der Spieler gewinnt.
package poker; import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Random; import java.util.concurrent.Callable; public class Game { public static void main(String[] args) { //定义5名玩家,使用List List<Player> playerList=new ArrayList<>(); playerList.add(new Player("于美人")); playerList.add(new Player("小婷子")); playerList.add(new Player("小晨子")); playerList.add(new Player("小艾")); playerList.add(new Player("小珍子")); //定义扑克牌顺序表 List<Card> cardList=new ArrayList<>(); //初始化扑克牌 initializeCards(cardList); System.out.println(cardList); //调用collections下的shuffle(洗牌)方法 //进行洗牌 Collections.shuffle(cardList); //System.out.println("抽牌前,牌组中的牌:"); System.out.println(cardList); //发牌 int n=2;//每名玩家发几张牌 for(int i=0;i<n;i++){//一共发n轮牌 for(Player player:playerList){//每名玩家一次抽牌 Card card=cardList.remove(0);//从牌组中,抽一张牌出来 player.cardList.add(card);//把这张牌放到当前玩家的手中 } } System.out.println("现在牌组中剩余的牌:"); System.out.println(cardList); System.out.println("交换牌之前:"); for(Player player:playerList){ System.out.printf("玩家[%s]的手牌是: %s%n",player.name,player.cardList); } //要找的牌,方法1 Card toFoundCard=new Card("♠",1); for(Player player:playerList){ for(Card card:player.cardList){ //比较每张牌和要找的是否为同一张牌 if(card.equals(toFoundCard)){ System.out.println(player.name+"获胜"); return; } } } System.out.println("无人获胜"); } //要找的牌,方法2 Card toFoundCard2=new Card("♠",1); for(Player player:playerList){ if(player.cardList.contains(toFoundCard)) { System.out.println(player.name + "获胜"); return; } } private static void initializeCards(List<Card> cards){ for(String suit:new String[]{"♠","♥","♦","♣"}){ for(int rank=1;rank<=5;rank++){ Card card=new Card(suit,rank); //把扑克牌放入牌组中 cards.add(card); } } }
2. Lassen Sie jeden Spieler der Reihe nach eine Karte aus der Hand seines nächsten Spielers ziehen und dann nach ♠A suchen.
//添加打印手牌的方法 public static void printPlayerHandCard(List<Player> playerList){ for(Player player:playerList){ System.out.printf("玩家[%s]的手牌是:%s%n",player.name,player.cardList); } } //集体实现交换的过程 //交换牌 //每名玩家随机抽取下家的一张牌 Random random=new Random(); for(int i=0;i<playerList.size();i++){ Player currentPlayer=playerList.get(i); //下家就是按照前后关系的下一个,最后一名玩家抽取第0个 Player nextPlayer=playerList.get(i!=playerList.size()-1?i+1:0); //要取的牌的下标 int toDrawIndex=random.nextInt(nextPlayer.cardList.size()); //取牌 Card drawCard=nextPlayer.cardList.remove(toDrawIndex); //放入当前玩家的手中 currentPlayer.cardList.add(drawCard); } System.out.println("交换牌之后:"); printPlayerHandCard(playerList);
3. Yu Meiren ist die Gottheit des Glücksspiels, sie hat die Fähigkeit, Karten zu ändern: Sobald sie kein ♠A auf der Hand hat, kann sie die erste Karte in ♠A ändern. (Vor dem Kartentausch besteht die Möglichkeit, einmal zu wechseln; nach dem Kartentausch besteht die Möglichkeit, einmal zu wechseln)
Card toFoundCard=new Card("♠",1); //已知于美人的下标为0 Player 于美人=playerList.get(0); if(!于美人.cardList.contains(toFoundCard)){ 于美人.cardList.set(0,toFoundCard); } System.out.println("于美人第一次发功:"); printPlayerHandCard(playerList); System.out.println("交换牌之后:"); printPlayerHandCard(playerList); //此处交换牌过程省略。。。。。。。。。。。。。。 if(!于美人.cardList.contains(toFoundCard)){ 于美人.cardList.set(0,toFoundCard); } System.out.println("于美人第二次发功:"); printPlayerHandCard(playerList);
Definieren Sie eine neue Spielerklasse:
package poker; import java.util.ArrayList; import java.util.List; public class Player { public List<Card> cardList=new ArrayList<>(); public String name; public Player(String name){ this.name=name; } }
Definieren Sie eine Spielkartenklasse:
package poker; import java.util.Objects; public class Card { public String suit;//花色 public int rank;//分值 //构造方法 public Card(String suit,int rank){ this.rank=rank; this.suit =suit; } @Override public String toString() { return String.format("[%s%d]",suit,rank); } //重写比较相等的方法 @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Card card = (Card) o; return rank == card.rank && Objects.equals(suit, card.suit); } }
Hinweis:
(1) Um die Überschreibung der Vergleichsgleichheitsmethode neu zu definieren.
(2) Achten Sie auf die Schreibweise der foreach-Methode.
Verwandte Empfehlungen: Java-Einführungs-Tutorial
Das obige ist der detaillierte Inhalt vonImplementieren Sie ein einfaches Pokerspiel mit Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Leitfaden zur perfekten Zahl in Java. Hier besprechen wir die Definition, Wie prüft man die perfekte Zahl in Java?, Beispiele mit Code-Implementierung.

Leitfaden für Weka in Java. Hier besprechen wir die Einführung, die Verwendung von Weka Java, die Art der Plattform und die Vorteile anhand von Beispielen.

Leitfaden zur Smith-Zahl in Java. Hier besprechen wir die Definition: Wie überprüft man die Smith-Nummer in Java? Beispiel mit Code-Implementierung.

In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Kapseln sind dreidimensionale geometrische Figuren, die aus einem Zylinder und einer Hemisphäre an beiden Enden bestehen. Das Volumen der Kapsel kann berechnet werden, indem das Volumen des Zylinders und das Volumen der Hemisphäre an beiden Enden hinzugefügt werden. In diesem Tutorial wird erörtert, wie das Volumen einer bestimmten Kapsel in Java mit verschiedenen Methoden berechnet wird. Kapselvolumenformel Die Formel für das Kapselvolumen lautet wie folgt: Kapselvolumen = zylindrisches Volumenvolumen Zwei Hemisphäre Volumen In, R: Der Radius der Hemisphäre. H: Die Höhe des Zylinders (ohne die Hemisphäre). Beispiel 1 eingeben Radius = 5 Einheiten Höhe = 10 Einheiten Ausgabe Volumen = 1570,8 Kubikeinheiten erklären Berechnen Sie das Volumen mithilfe der Formel: Volumen = π × R2 × H (4

Spring Boot vereinfacht die Schaffung robuster, skalierbarer und produktionsbereiteter Java-Anwendungen, wodurch die Java-Entwicklung revolutioniert wird. Der Ansatz "Übereinkommen über Konfiguration", der dem Feder -Ökosystem inhärent ist, minimiert das manuelle Setup, Allo
