java实现简单扑克牌游戏

 更新时间:2020年09月23日 10:13:43   作者:sherry.*  
这篇文章主要为大家详细介绍了java实现简单扑克牌游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了java实现简单扑克牌游戏的具体代码,供大家参考,具体内容如下

扑克牌小游戏:

游戏玩法简介:定义五个People在玩扑克牌游戏,玩法是5个人从一副没有大小王的扑克牌中各抽取4张,牌的类型有四种:♥,♣,♠,♦。牌的大小为从1~13。(此处为了简单,只取1 -5).

1.黑桃♠A在哪名玩家手中,哪名玩家就获胜。

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.让每名玩家,依次抽取他的下家的一张手牌,然后再找♠A,找到♠A就获胜。

//添加打印手牌的方法
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.于美人是赌神,她有变牌能力:她手中一旦没有♠A,她就可以把第一张牌变成♠A。(交换牌之前,有机会变一次;交换牌之后,有机会变一次)

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);

定义玩家新的的一个类:

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;
  }
}

定义扑克牌的一个类:

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);
  }
}

注意:

(1)要重新定义比较相等方法的重写。
(2)注意foreach 方法的写法。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • jasypt SaltGenerator接口定义方法源码解读

    jasypt SaltGenerator接口定义方法源码解读

    这篇文章主要为大家介绍了jasypt SaltGenerator接口定义方法源码解读,,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Spring线程池ThreadPoolExecutor配置并且得到任务执行的结果

    Spring线程池ThreadPoolExecutor配置并且得到任务执行的结果

    今天小编就为大家分享一篇关于Spring线程池ThreadPoolExecutor配置并且得到任务执行的结果,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • java批量下载生成zip压缩包的思路详解

    java批量下载生成zip压缩包的思路详解

    这篇文章主要介绍了java批量下载生成zip压缩包的思路详解,设计思路大概是本地先创建一个zip文件,将批量下载的文件依次放入zip文件中,将zip文件返回给前端,本文结合实例代码讲解的非常详细,需要的朋友可以参考下
    2024-01-01
  • Spring boot实现一个简单的ioc(1)

    Spring boot实现一个简单的ioc(1)

    这篇文章主要为大家详细介绍了Spring boot实现一个简单的ioc,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • 剖析Java中阻塞队列的实现原理及应用场景

    剖析Java中阻塞队列的实现原理及应用场景

    这篇文章主要介绍了剖析Java中阻塞队列的实现原理及应用场景,这里也对阻塞和非阻塞队列的不同之处进行了对比,需要的朋友可以参考下
    2015-12-12
  • Spring Boot定时任务单线程多线程实现代码解析

    Spring Boot定时任务单线程多线程实现代码解析

    这篇文章主要介绍了Spring Boot定时任务单线程多线程实现代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • Java实现定时任务的示例代码

    Java实现定时任务的示例代码

    这篇文章主要为大家详细介绍了Java实现定时任务的相关知识,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-11-11
  • Java聊天室之实现聊天室客户端功能

    Java聊天室之实现聊天室客户端功能

    这篇文章主要为大家详细介绍了Java简易聊天室之实现聊天室客户端功能,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以了解一下
    2022-11-11
  • 一文彻底理清SpringBoot CURD处理逻辑、顺序

    一文彻底理清SpringBoot CURD处理逻辑、顺序

    这篇文章主要给大家介绍了关于如何一文彻底理清SpringBoot CURD处理逻辑、顺序的相关资料,CURD是一个数据库技术中的缩写词,一般的项目开发的各种参数的基本功能都是CURD,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • JSON--List集合转换成JSON对象详解

    JSON--List集合转换成JSON对象详解

    这篇文章主要介绍了List集合转换成JSON对象,小编觉得挺不错的,现在就分享给大家,也给大家做个参考。
    2017-01-01

最新评论