发牌洗牌的简单逻辑

news2024/11/28 12:53:18

1. 需求分析

1.1 要求实现:

        我们能使用一副牌,基本的实现多人炸金花小游戏。

1.2 实现分析:

        1、有一副牌:

        首先自定义card类,来定义每一张牌;(牌上由花色和数字(1~13))

        其次生成一副牌(实例化52张牌,然后将这些牌都放在一个盒子中(盒子的数据存储结构是顺序表))

        2、洗牌:

        对于上一个步骤产生的52张牌应该是有序的,我们应该打乱顺序:

        采用交换方法来洗牌,即:

        令i=51,随机生成一个1~50的序号,让其和i进行交换;

        然后令i=50,随机生成一个1~49的序号,让其和i进行交换;

        ……

        直到i=1,停止交换,此刻就可以得到一个无序的牌堆;

        3、抓牌

        1)怎么抓牌和抓的牌存放问题?

        创建多个顺序表,每个顺序表来表示存放个人的牌,将多人的逻辑关系做成二维数组,每个人轮流抓第一张,其次第二轮各自抓第二张;

                                ​​​​​​​        

        注意:当第一个人抓到索引为1的牌后,此刻的牌堆其余的51张牌的索引都会往前移一个单位,对于第一轮第二个人抓牌时,此时每个索引对应的每张牌和之前不一样------>所以使用arraylist的删除操作模型来解决这一问题。

2、代码展现及分析

        面向对象思想解决问题主要分为这3步:

  • 找出其中的所有的对象(card类)
  • 实现所有的对象
  • 完成对象之间的交互(洗牌,展示牌,抓牌)

         如图所示为项目架构:

2.1 card类

        自定义扑克类,描述扑克牌的属性为花色(type)和数字(number),再重写 toString方法(使牌的输出简单明了)

public class Card {
    private String type;
    private int number;

    public Card(String type, int number) {
        this.type = type;
        this.number = number;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public int getNumber() {
        return number;
    }

    public void setNumber(int number) {
        this.number = number;
    }

    @Override
    public String toString() {
        return
                "["+type + ":"+number+"]" ;
    }
}

2.2 CardOperation类

        1、首先生成一副牌

public class CardOperation {
    private final String[] types = {"♥","♠","♦","♣"};
        //首先生成一副牌
        //之前是每一张牌构造,现在是创建一盒牌,存放在cardList里面
        //且通过这个方法之后,返回一盒牌
    public List<Card> makeCards(){
        List<Card> cardList = new ArrayList<>();
        for (int i = 1; i <= 13; i++) {
            for (int j = 0; j <4 ; j++) {
                Card card = new Card(types[j],i);//详细的实例化每一张牌
                cardList.add(card);//将生成的牌放入到牌盒子里面
            }
        }
        return cardList;//刚放到盒子里的牌是有序的
    }
}

运行测试代码及结果:

public class Test {
    public static void main(String[] args) {
        CardOperation cardOperation = new CardOperation();
        List<Card> cardList = cardOperation.makeCards();
        System.out.println("我说:要有一副牌");
        System.out.println(cardList);
    }

}

        2、对生成的有序牌进行洗牌----打乱顺序

 public void showerCards(List<Card> cardList){
        Random random = new Random();
        for (int i = cardList.size()-1; i > 0; i--) {
            int index = random.nextInt(i);
            //index  i 交换
            swap(cardList,i,index);
        }
    }

    private void swap(List<Card> cardList,int a,int b){
        Card tmp = cardList.get(a);
        cardList.set(a,cardList.get(b));
        cardList.set(b,tmp);//把b下标的牌放到a下标
    }

        运行测试代码及结果: 

 3、抓牌

public void getCard(List<Card> cardList) {
        //从牌盒子里抓牌
        //将三个人关系做成二维数组
       List<Card> people1 = new ArrayList<>();
       List<Card> people2 = new ArrayList<>();
       List<Card> people3 = new ArrayList<>();
       List<Card> people4 = new ArrayList<>();

       List<List<Card>> peoples = new ArrayList<>();
       peoples.add(people1);
       peoples.add(people2);
       peoples.add(people3);
       peoples.add(people4);

        for (int i = 0; i <= 5; i++) {
           // i代表第几次抓牌
            for (int j = 0; j < 4; j++) {
                //j代表人
                Card card = cardList.remove(0);
                peoples.get(j).add(card);
            }
        }

        System.out.println("第1个揭牌如下:");
        System.out.println(people1);
        System.out.println("第2个揭牌如下:");
        System.out.println(people2);
        System.out.println("第3个揭牌如下:");
        System.out.println(people3);
        System.out.println("第4个揭牌如下:");
        System.out.println(people4);

        System.out.println("剩下的牌:");
        System.out.println(cardList);

        总运行代码及结果: 

 public static void main(String[] args) {
        CardOperation cardOperation = new CardOperation();
        List<Card> cardList = cardOperation.makeCards();
        System.out.println("我说:要有一副牌");
        System.out.println(cardList);

        System.out.println("我说,要洗牌");
        cardOperation.showerCards(cardList);
        System.out.println(cardList);
        System.out.println("我说,亮牌");
        cardOperation.getCard(cardList);
        System.out.println(cardList);
    }

 

ps:本次内容就到这里了,喜欢的话,还请大家一键三连!!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1266681.html

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

相关文章

第二十章多线程

线程简介 java语言提供了并发机制&#xff0c;程序员可以在程序中执行多个线程&#xff0c;每一个线程完成一个功能&#xff0c;并与其他线程并发运行。 一个进程是一个包含有自身地址的程序&#xff0c;每个独立执行的程序都称为进程。也就是说每个正在执行的程序都是一个进…

基于QT的俄罗斯方块游戏设计与实现

基于QT的俄罗斯方块游戏设计与实现 摘要&#xff1a;信息时代正处于高速发展中&#xff0c;而电子游戏已经成为人生活中或不可少的消磨工具之一。科技时代在不断地高速发展中&#xff0c;游戏相关编程设计也随着发展变得越来越重要&#xff0c; 俄罗斯方块游戏是一款古老传遍世…

ubuntu22.04新机使用(换源,下载软件,安装显卡驱动,锁屏长亮)

换源 国内有很多Ubuntu的镜像源&#xff0c;包括阿里的、网易的&#xff0c;还有很多教育网的源&#xff0c;比如&#xff1a;清华源、中科大源。推荐使用中科大源&#xff0c;快得很。 /etc/apt/sources.list编辑/etc/apt/sources.list文件, 在文件最前面添加以下条目(操作前…

促进高层次人才创新创业,长沙又在“放大招”

“人才”&#xff0c;寥寥数笔&#xff0c;却勾勒出一座城市的发展核心、创新引擎。大力引进高层次人才&#xff0c;更是城市提升综合实力的有效举措。 11月26日&#xff0c;在长沙市委组织部&#xff08;市委人才工作局&#xff09;举办“汇聚磅礴力量 全力建设全球研发中心城…

港科夜闻|2023年全球大学毕业生就业力排名公布,香港科大位列香港第一名

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、2023年全球大学毕业生就业力排名公布&#xff0c;香港科大位列香港第一名。香港科大在泰晤士高等教育2023年全球就业能力大学排名中上升一位至全球第29位&#xff0c;继续位居香港首位。香港科大的毕业生就业能力持续跻身…

水淼采集器-免费水淼采集器下载

在当今数字时代&#xff0c;随着信息的迅猛增长&#xff0c;许多网站管理员面临一个共同而具有挑战性的问题——如何在短时间内获取大量优质内容&#xff0c;以满足用户对信息的不断需求&#xff1f;水淼采集器&#xff0c;作为一个备受瞩目的解决方案&#xff0c;正成为许多人…

浅谈数据资产价值评估

加gzh"大数据食铁兽“&#xff0c;了解更多大数据信息 数据是资产&#xff0c;是当前时代大背景下毋庸置疑的。随着科技的发展&#xff0c;数据的重要性越来越受到人们的关注。对于企业来说&#xff0c;数据是非常重要的资产&#xff0c;它可以为企业提供决策依据、增加市…

Leetcode—2336.无限集中的最小数字【中等】

2023每日刷题&#xff08;四十四&#xff09; Leetcode—2336.无限集中的最小数字 实现代码 class SmallestInfiniteSet {set<int> s; public:SmallestInfiniteSet() {for(int i 1; i < 1000; i) {s.insert(i);}}int popSmallest() {int res *s.begin();s.erase(s…

解决git action发布失败报错:Error: Resource not accessible by integration

现象&#xff1a; 网上说的解决方法都是什么到github个人中心setting里面的action设置里面去找。 可这玩意根本就没有&#xff01; 正确解决办法&#xff1a; 在你的仓库页面&#xff0c;注意是仓库页面的setting里面&#xff1a; Actions> General>Workflow permisss…

2020年6月15日 Go生态洞察:pkg.go.dev开源探索

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Spring Cloud 版本升级记:OpenFeignClient与Gateway的爱恨交织

Spring Cloud 版本升级记&#xff1a;OpenFeignClient与Gateway的爱恨交织 近日&#xff0c;在负责的项目中&#xff0c;我对 Spring Boot、Spring Cloud 以及 Spring Cloud Alibaba 进行了版本升级。原以为会一切顺利&#xff0c;没想到却遭遇了 Spring Cloud Gateway 无法正…

创新、诚信、共赢:湖北乾一律师事务所领航律师行业新发展

湖北乾一律师事务所: 一、引言 律师行业在现代社会中扮演着举足轻重的角色,为公民、法人和其他组织提供法律服务,维护法律权益,促进法治建设。湖北乾一律师事务所作为业内的佼佼者,凭借其专业素养、丰富经验和卓越声誉,成为了律师行业的典范。 二、湖北乾一律师事务所概况 …

宋仕强论道之华强北的商业配套(十三)

宋仕强论道之华强北的商业配套&#xff08;十三&#xff09;&#xff1a;金航标电子萨科微半导体总经理宋仕强先生发布“宋仕强论道”系列视频&#xff0c;分享多年学习、生活和工作经验和感悟&#xff0c;甚至涵盖了文学、艺术、哲学、宗教。这段时间发表的是对华强北&#xf…

Oracle(2-7)Instance and Media Recovery Structures

文章目录 一、基础知识1、体系结构详解2、Database Files 数据库文件3、Database Other Files 其他数据文件4、Dynamic Views 动态视图5、Large Pool6、DB Buffer Cache,DBWn7、Configuring Tablespaces 配置表空间8、Redo Log Buffer, LGWR9、Database Checkpoints 数据库检查…

【MySql】悲观锁和乐观锁的介绍

一、并发控制 当程序中可能出现并发的情况时&#xff0c;就需要保证在并发情况下数据的准确性&#xff0c;以此确保当前用户和其他用户一起操作时&#xff0c;所得到的结果和他单独操作时的结果是一样的。这就叫做并发控制。并发控制的目的是保证一个用户的工作不会对另一个用…

在Anaconda中用命令行安装环境以及安装包

一、下载Anaconda 下载地址 二、创建环境 1. 打开Anaconda命令行 2.创建环境 conda create -n 环境名称 python3.10(需要的python版本号) 3.激活环境 activate 环境名4.下载安装包 pip install 模块名 -i https://pypi.tuna.tsinghua.edu.cn/simple5.下载torch 官网&…

Cesium 关闭深度写入

没有关闭PointPrimitive的深度写入: 关闭了PointPrimitive的深度写入: if (pointPrimitiveCollection._rsOpaque) {pointPrimitiveCollection._rsOpaque Cesium.RenderState.fromCache({depthTest: {enabled: false,}});}const p pointPrimitiveCollection.add({position:…

Softing线上研讨会 I 用于现代工业物联网的OPC UA服务器聚合管理方案

| 线上研讨会时间&#xff1a;2023年12月4日 17:00~17:30或23:00~23:30 在工业自动化网络中有越来越多的设备通过OPC UA互操作性标准来传输数据&#xff0c;同时&#xff0c;在用户端也有越来越多的IT应用支持OPC UA。然而&#xff0c;为了加速OT和IT之间的融合&#xff0c;必…

P9242 [蓝桥杯 2023 省 B] 接龙数列(dp+最长接龙序列+分类)

1. 计算0~9为结尾的最长子串长度 2. 对于每个数字&#xff0c;比较其开头可连接子串长度1 与 原来以其末位为末尾的子串长度 3. 更新以其末位为末尾的子串长度 #include<iostream> #include<string.h>using namespace std;// 相当于记录…

苹果手机怎么卸载微信?记得掌握这两种方法!

微信是一款社交应用程序&#xff0c;在聊天过程中&#xff0c;我们会经常发送和接收各种形式的信息。随着时间的推移&#xff0c;微信缓存的文件会越来越多&#xff0c;占用的存储空间也会逐渐增加。 卸载微信可以释放手机内存&#xff0c;提高手机的运行速度。那么&#xff0…