当前位置: 首页 > article >正文

java之斗地主部分功能的实现

今天我们要实现斗地主中发牌和洗牌这两个功能,该如何去实现呢?

1.创建牌类:52张牌每一张牌包含两个属性:牌的大小和牌的花色。

故我们优先创建一个牌的类(Card):包含大小和花色。

public class Card {   //单张牌的大小及类型
    //牌的花色,数量及返回值
   private String suit; //花色
    private int rank; //大小

    public Card(String suit, int rank){   //牌的构造方法
       this.suit = suit;
       this.rank = rank;
    }
    @Override
    public String toString(){ //返回这张牌的属性
        return "{" + suit+rank+ "}";
    }
}

2.牌类创建好之后,我们就可以再创建一个CardDemo类来着重实现它的功能。

2.1:扑克牌的创建:

   实现功能之前我们要有一个容纳52张牌的数组(列表),其中这52张卡牌有四种花色,并且有1~13的大小(暂定),我们就要创建一个字符数组来存储其花色类型,再创建一个可以存储Card类型的泛型列表cardList来存放52张扑克牌,之后,通过两个for循环,一个通过花色(suit),一个通过牌的大小(rank),将每次循环的成员属性(suit、rank)放到新创建的卡牌类card中,最后通过add方法将这个新牌添加到cardList列表中,具体代码如下:

 public List<Card> buyCard(){    
        List<Card> cardList = new ArrayList<>();  //创建牌的列表
        //大小为i的牌的四张j类型的花色
        for (int i = 1; i <=13 ; i++) {
            for(int j =0;j<4;j++)
            {
                int rank = i; //第i张牌
                String suit = suits[j] ; // j类型的花色
                Card card = new Card(suit,rank); //获取新的牌
                cardList.add(card);//将这个牌添加到列表中
            }
        }
     return cardList;
    }

         

  2.2    洗牌功能的实现:

如何进行随机洗牌呢?

想到随机二字,你是否联想到了Random函数?我们不妨用下面的思路来解决这个问题:

从最后一张牌(索引为51)开始,for循环,通过random函数随机获取前i-1(i是最后一张牌的索引)张牌的索引,通过索引与最后张牌进行交换。这样一套循环下来可以实现随机洗牌的功能。

具体代码如下:

    //洗牌功能的实现:
    public void shuffle(List<Card> cardList){
        Random random = new Random();
        for (int i = cardList.size()-1; i >0 ; i--) {
            //将第i位置的元素与索引为0~i-1的元素进行交换位置
            int index = random.nextInt(i); //随机获取索引为0~i-1的位置
            swap(cardList,i,index); //将位置index的元素和i像交换
        }
    }

那么这里问题又来了,如何实现交换两个牌的方法swap呢?通过ArrayList中的get、set方法获取、设置元素,通过类似于创建第三变量的方式将两个元素实现交换,不同的是作为媒介的第三方元素类型必须是Card。

 private void swap(List<Card> cardList,int i,int j)
    {
        Card tmp = cardList.get(i); //将i位置的元素赋值给tmp
        cardList.set(i,cardList.get(j)); //将j位置的元素赋值到i位置
        cardList.set(j,tmp);  //tmp与j位置的元素互换
    }

2.3:发牌功能的实现:

          假设一共有三个人    假设每个人分到的手牌为5张,则先分别创建3个泛型为Card的列表用来存储这三个人分到的手牌,之后再创建一个二维列表hand来存储三个人的手牌,便于管理和访问不同玩家或不同伦次的手牌。

发牌过程中,两个for循环一次给每个人发牌,发牌时需要注意,第一张牌被人抽走之后,第二张牌便排在了第一位,这里我们每次发牌前移除第一个元素,并将这个移除元素分给对应 的人。

public List<List<Card>> play(List<Card> cardList) {
        List<Card> hand0 = new ArrayList<>();
        List<Card> hand1 = new ArrayList<>();
        List<Card> hand2 = new ArrayList<>();
        List<List<Card>> hand = new ArrayList<>();
         hand.add(hand0);
         hand.add(hand1);
         hand.add(hand2);

         for(int i=0;i<5;i++) //5张牌
         {
             for (int j = 0; j < 3; j++) { //3个人
                  Card card = cardList.remove(0); //移除第一张牌,并将这张移除的牌赋给card,同时下一次card的第二个元素变为第一个
                  //把对应的牌放到对应的人手中
                 hand.get(j).add(card);
             }
         }
         return hand;
     }

}

3.在main方法里进行测试:

public class Test {
    public static void main(String[] args) {
        CardDemo cardDemo = new CardDemo();
        //1.创建52张牌
        List<Card> cardList = cardDemo.buyCard();
        System.out.println(cardList);
          //2.洗牌:
        cardDemo.shuffle(cardList);
        System.out.println(cardList);
        //3每个人拿五张牌
        List<List<Card>> ret = cardDemo.play(cardList);
        for (int i = 0; i < ret.size(); i++) {
            System.out.println("第"+(i+1)+"个人的牌:"+ret.get(i));
        }
        System.out.println("剩下的人的牌");
        System.out.println(cardList);

    }
}

实现后:


http://www.kler.cn/a/319142.html

相关文章:

  • 不对称信息
  • 【MySQL】数据库表连接简明解释
  • ODOO学习笔记(8):模块化架构的优势
  • 编译ffmpeg动态库时设置RPATH为$ORIGIN
  • 深入理解接口测试:实用指南与最佳实践5.0(二)
  • nuxt3添加wowjs动效
  • 修改Linux服务器系统语言
  • 深入解析Debian与Ubuntu:技术特点与用户使用指南
  • Git 详细安装教程(详解 Git 安装过程的每一个步骤)
  • Python 课程19-FastAPI
  • 开源 AI 智能名片与 S2B2C 商城小程序:嫁接权威实现信任与增长
  • 深入解析:HTTP 和 HTTPS 的区别
  • 51单片机开关电路+限位+舵机
  • 【玉米田】
  • Springboot多种请求参数
  • Cloudera 安装不再难:下载安装全流程指南
  • 数据库基础01
  • 《使用 LangChain 进行大模型应用开发》学习笔记(四)
  • 【图论】最短路应用
  • 封面设计用什么软件最高效?分享5款新手必备工具
  • 数据报文解析
  • 【CSS】变量的声明与使用
  • 水电站/水库大坝安全监测系统完整解决方案
  • 抖音上下边框中间视频效果怎么做
  • 效率提升的秘密武器在快速编程领域的应用与探索
  • GPU架构原理与CUDA编程原理