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

news2025/1/20 22:05:38

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

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.coloradmin.cn/o/2153446.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

20240921在友善之臂的NanoPC-T6开发板上使用Rockchip原厂的Android12适配宸芯的数传模块CX6602N

127|console:/ # uname -a console:/ # ifconfig console:/ # ifconfig -a console:/ # ifconfig -a 130|console:/ # ifconfig usb0 192.168.42.130 console:/ # console:/ # ifconfig console:/ # iperf3 -s & iperf3 -c 192.168.42.130 -i 1 -t 30 20240921在友善之臂的…

828华为云征文|华为云Flexus云服务器X实例之openEuler系统下部署Grav内容管理系统

828华为云征文&#xff5c;华为云Flexus云服务器X实例之openEuler系统下部署Grav内容管理系统 前言一、Flexus云服务器X实例介绍1.1 Flexus云服务器X实例简介1.2 Flexus云服务器X实例特点1.3 Flexus云服务器X实例使用场景 二、Grav介绍2.1 CMS介绍2.2 Grav简介2.3 Grav特点2.4 …

TinyML-On-The-Fly: 实时、低功耗、低成本的微控制器嵌入式设备内计算机视觉技术用于无人机图像分类

这篇论文的标题是《TinyML-On-The-Fly: Real-Time Low-Power and Low-Cost MCU-Embedded On-Device Computer Vision for Aerial Image Classification》&#xff0c;作者是 Riya Samanta, Bidyut Saha, Soumya K. Ghosh&#xff0c;来自印度理工学院克勒格布尔分校。论文主要研…

电子元器件之MOS管,附上几个常用MOS管电路和仿真。

MOS管是一种常用的电子元器件。 1.MOS管的类别 MOSFET简称MOS&#xff0c;是一种绝缘栅型场效应管。按照类别可以分为增强型mos管和耗尽型mos管。 导电沟道的形成方式‌ 增强型MOS管&#xff1a;在没有外加电压时&#xff0c;源极和漏极之间没有导电沟道存在。只有当栅极电…

【玉米田】

题目 代码 #include <bits/stdc.h> using namespace std; typedef long long LL;const int mod 1e8; const int M 1 << 12; LL f[13][M]; int g[13]; vector<int> state; vector<int> p[M]; int n, m; bool check(int x) {return !(x & x <&…

攻防世界---->Windows_Reverse1(补)

做题笔记。 做题回顾。 假设&#xff0c;我们不知道地址随机怎么办&#xff1f;不能动调&#xff0c;只能静态分析。 下载 查壳 upx脱壳。 32ida打开。 动调报错。 重新打开&#xff0c;静态分析。 跟进关键函数。 不明白可以反汇编和汇编一起看。 溯源。 *decode 取值等于 by…

分布式锁之 防误删(优化之UUID防误删)

文章目录 1、AlbumInfoApiController --》testLock()2、AlbumInfoServiceImpl --》testLock()3、问题&#xff1a;删除操作缺乏原子性。 实现如下&#xff1a; 1、AlbumInfoApiController --》testLock() Tag(name "专辑管理") RestController RequestMapping(&quo…

【计网】从零开始掌握序列化与反序列化 --- 基础知识储备与程序重构

从零开始掌握序列化与反序列化 1 初识序列化与反序列化2 再谈Tcp协议3 程序重构3.1 Socket类3.2 回调函数设计3.3 最终的Tcp服务器类 1 初识序列化与反序列化 在刚学习计算机网络时&#xff0c;我们谈到过网络协议栈&#xff0c;其中最上层的就是应用层&#xff0c;那么这个应…

Qt圆角窗口

Qt圆角窗口 问题&#xff1a;自己重写了一个窗口&#xff0c;发现用qss设置圆角了&#xff0c;但是都不生效&#xff0c;不过子窗口圆角都生效了。 无边框移动窗口 bool eventFilter(QObject *watched, QEvent *evt) {static QPoint mousePoint;static bool mousePressed f…

开源、极简的B站第三方,建议所有人收藏

很多人说B站落寞了&#xff0c;但我觉得不是B站落寞&#xff0c;而是长视频落寞了。现代人已经没有充足的耐心&#xff0c;刷完一个十分钟的视频。毕竟&#xff0c;短视频可以把这十分钟切成50份&#xff0c;让我们开心50次。 可怕的是&#xff0c;B站即使落寞&#xff0c;在长…

继承的例题

答案&#xff1a;D 解析&#xff1a;C允许一个子类继承多个父类 知识点&#xff1a; 子类是父类的特殊化&#xff0c;父类是子类的泛化 解析&#xff1a;子类可以共享父类的属性和方法&#xff0c;选项A正确 面向对象关系中&#xff0c;类与类的关系包含继承&#xff0c;包…

IntelliJ IDEA 2024.1.4 (Ultimate Edition)找不到Add Framework Support解决方法

目录 背景: 解决方法&#xff1a; 步骤1: 步骤2&#xff1a; 步骤3&#xff1a; 创建Web项目的完整流程&#xff1a; 步骤1: 步骤2: 步骤3&#xff1a; 步骤4&#xff1a; Web优点: 背景: 我的IDE版本是IntelliJ IDEA 2024.1.4 (Ultimate Edition)&#xff0c;当我…

【优选算法之双指针】No.2--- 经典双指针算法(下)

文章目录 前言一、双指针示例&#xff1a;1.1 ⽔果成篮1.2 和为s的两个数字1.3 三数之和1.4 四数之和 二、双指针总结&#xff1a; 前言 &#x1f467;个人主页&#xff1a;小沈YO. &#x1f61a;小编介绍&#xff1a;欢迎来到我的乱七八糟小星球&#x1f31d; &#x1f4cb;专…

前后端分离,使用MOCK进行数据模拟开发,让前端攻城师独立于后端进行开发

mock是什么 Mock生成随机数据,拦截Ajax 请求&#xff0c;前后端分离&#xff0c;让前端攻城师独立于后端进行开发。 增加单元测试的真实性 通过随机数据,模拟各种场景。 在实际开发过程中&#xff0c;前端是通过axios来请求数据的&#xff0c;很多时候前端开发者就是通过写固定…

【Git必看系列】—— Git巨好用的神器之git stash篇

应用场景 当我们开发一个新功能时会先从master拉出一个分支dev&#xff0c;然后在这个dev分支下吭哧吭哧的开始写代码开发新功能&#xff0c;就如下代码所示&#xff0c;我们在dev分支下开发Person类的新功能getId() public class Person {private int id;private String nam…

Vue3:v-model实现组件通信

目录 一.性质 1.双向绑定 2.语法糖 3.响应式系统 4.灵活性 5.可配置性 6.多属性绑定 7.修饰符支持 8.defineModel使用 二.使用 1.父组件 2.子组件 三.代码 1.父组件代码 2.子组件代码 四.效果 一.性质 在Vue3中&#xff0c;v-model指令的性质和作用主要体现在…

vue3 快速入门系列 —— 基础

基础 前面我们已经用 vue2 和 react 做过开发了。 AIAutoPrediction 从 vue2 升级到 vue3 成本较大&#xff0c;特别是较大的项目。所以许多公司对旧项目继续使用vue2&#xff0c;新项目则使用 vue3。 有些UI框架&#xff0c;比如ant design vue1.x 使用的 vue2。但现在 an…

5.C++面向对象2(类对象大小计算,结构体内存对齐,大小端存储方式,this指针)

⭐本篇文章为C学习第4章&#xff0c;主要了解类对象大小和this指针 ⭐本人C代码仓库&#xff1a;yzc的c学习: 小川c的学习记录 - Gitee.com 目录 一. 类对象模型 1.1 类成员函数和成员变量的分布 1.2 如何计算类的大小&#xff1f;&#xff08;结构体内存对齐&#xff09…

卸载node,安装nvm的详细使用方法

一、nvm是什么&#xff1f; nvm是一个node的版本管理工具&#xff0c;可以简单切换的node版本、安装、查看。。。等等&#xff0c;与npm不同的是&#xff0c;npm是依赖包的管理工具。 二、nvm下载安装 安装之前需要先把 自己电脑上边的node给卸载了&#xff0c;不然安装不好…

【数据结构初阶】链式二叉树接口实现超详解

文章目录 1. 节点定义2. 前中后序遍历2. 1 遍历规则2. 2 遍历实现2. 3 结点个数2. 3. 1 二叉树节点个数2. 3. 2 二叉树叶子节点个数2. 3. 3 二叉树第k层节点个数 2. 4 二叉树查找值为x的节点2. 5 二叉树层序遍历2. 6 判断二叉树是否是完全二叉树 3. 二叉树性质 1. 节点定义 用…