基于ArrayList实现简单洗牌

news2025/1/16 14:02:18

前言

在之前的那篇文章中,我们已经认识了顺序表—>http://t.csdnimg.cn/2I3fE

基于此,便好理解ArrayList和后面的洗牌游戏了。

什么是ArrayList?

 ArrayList底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表,与普通数组的区别就是它是没有固定大小的限制。

ArrayList的一些常见操作

首先我们要导入一个ArrayList包

import java.util.ArrayList;

在正式调用方法之前,别忘了创建一个ArrayList对象哦~

ArrayList<String> list = new ArrayList<>();

在这里,我就创建了一个只能存储String类型数据的ArrayList(顺序表)

下面便是ArrayList一些常见的使用方法,仔细观察就不难发现这些方法在模拟实现顺序表的时候就已经实现过了,现在直接用就行了,若有不记得了,可查看帮助手册-->Overview (Java SE 17 & JDK 17)

import java.util.ArrayList;

public class commonTest {
        public static void main(String[] args) {
            // 创建一个ArrayList并添加一些元素
            ArrayList<String> list = new ArrayList<>();
            list.add("apple");
            list.add("banana");
            list.add("orange");

            // 使用get方法获取指定位置的元素
            String fruit = list.get(1);
            System.out.println("下标为1的水果是: " + fruit);

            // 使用set方法替换指定位置的元素
            list.set(0, "hello");
            System.out.println("替换之后 " + list);

            // 使用remove方法移除指定位置的元素
            list.remove(2);
            System.out.println("移除之后 " + list);

            // 使用size方法获取列表大小
            int size = list.size();
            System.out.println("列表大小: " + size);

            // 使用contains方法判断列表是否包含指定元素
            boolean containsBanana = list.contains("banana");
            System.out.println("是否包含banana " + containsBanana);
        }
    }

运行结果如图


运用之实现简单洗牌

纸牌相信大家都接触过,来看看如何利用ArrayList去实现洗牌?

这才是本文的重点哦~理论最终还是要服务与实践的,接下来就由我来带着各位看官来实现吧~

首先思考:

要洗牌,首先要有牌,想要表示出来,那么便要想好牌的属性--->花色和数字,好,那么就可以定义一个Card类专门存储这个,看下图:

public class Card {
    public int rank; // 表示牌面的数字
    public String suit; // 表示花色

    // 构造方法,用于初始化牌的数字和花色
    public Card(int rank, String suit) {
        this.rank = rank;
        this.suit = suit;
    }
    
    // 重写toString()方法,以便打印Card对象时能够直观地展示牌的信息
    @Override
    public String toString() {
        return "Card{" + suit + "  " + rank + "}";
    }
}

这样一来,这个Card类很好地封装了扑克牌的属性。

一张牌肯定不够,一副牌有52张(去掉大小王)---4个花色,1到13的数字,在洗牌之前,先有一副完整的牌才行显示出来才行

于是就新定义一个Cards类,规定好牌的花色

public static final String[] suits = {"♥", "♠", "♣", "♦"};//定义四种花色

还记得final 的作用吗?这里用final 修饰就是为了不被修改

接着通过两个循环,一个遍历花色,一个遍历数字 ,这样一张新牌就创建好了,别忘了要创建存放牌的List,这里就导入了ArrayList包以便用add方法了。

import java.util.ArrayList;
import java.util.List;
// 买一副牌
public List<Card> buyCards() {
    List<Card> cardList = new ArrayList<>(); // 基于ArrayList创建一个用于存放牌的List

    for (int i = 0; i < 4; i++) { // 循环四种花色
        for (int j = 0; j < 13; j++) { // 循环13个数字(2-10,J,Q,K,A)
            int rank = j; // 当前数字
            String suit = suits[i]; // 当前花色
            Card card = new Card(rank, suit); // 创建一张新的牌对象
            cardList.add(card); // 将新牌加入到牌组中
        }
    }
    
    return cardList; // 返回完整的一副牌
}

此时运行便是这个样子

这下牌有了那就开始洗牌了,洗牌肯定讲究随机,讲到随机少不了Random方法,要调用它,也到导入对应的Random包。将生成的随机数对应的牌(看索引)在遍历的过程中与每个牌的位置进行交换,这样便完成了洗牌,配合代码食用效果更佳~

import java.util.Random;
// 洗牌
public void shuffle(List<Card> cardList) {
    Random random = new Random(); // 创建一个随机数生成器

    for (int i = cardList.size(); i > 0; i--) { // 从最后一张牌开始向前遍历
        int index = random.nextInt(i); // 生成一个随机的索引
        swap(cardList, i - 1, index); // 将当前牌与随机选出的牌进行交换
    }
}

// 洗牌的原理-交换
public void swap(List<Card> cardList, int i, int j) {
    Card tmp = cardList.get(i); // 临时保存第i张牌
    cardList.set(i, cardList.get(j)); // 将第i张牌替换为第j张牌
    cardList.set(j, tmp); // 将第j张牌替换为临时保存的牌
}

还记得set方法是干嘛的吗?--->替换指定位置的元素,常见的记住可以提高效率的

此时效果是这样的 

那么到此牌洗好了,那就开始发牌,假设我们有三个人打牌,为了方便展示,就每人抽4张牌,思考一下,拿到牌后是不是也要存储才是?于是便要创建3个List去接受摸到的牌

// 发牌,三个人,每个人轮流摸4
public void drawCard(List<Card> cardList) {
    List<Card> hand1 = new ArrayList<>(); // 第一个人的手牌
    List<Card> hand2 = new ArrayList<>(); // 第二个人的手牌
    List<Card> hand3 = new ArrayList<>(); // 第三个人的手牌

    List<List<Card>> hand = new ArrayList<>(); // 存放三个人的手牌列表
    hand.add(hand1);
    hand.add(hand2);
    hand.add(hand3);

    for (int i = 0; i < 4; i++) { // 每个人轮流摸4张牌
        for (int j = 0; j < 3; j++) { // 三个人依次摸牌
            Card card = cardList.remove(0); // 从牌组中抽取一张牌,并从原来的牌组中移除
            hand.get(j).add(card); // 将抽取的牌加入到对应人的手牌列表中
        }
    }
    
    // 打印每个人摸到的牌
    System.out.println("第1个人摸到的牌:" + hand1);
    System.out.println("第2个人摸到的牌:" + hand2);
    System.out.println("第3个人摸到的牌:" + hand3);
    
}

开始摸牌,用嵌套循环去模拟分发,这里要明白为啥每次只remove(0),这是因为存储牌的也是是基于ArrayList的List,每次移除第一个元素,后续的元素会自动补上,这样一来,每次遍历,下标为0的元素就是原来的下一张牌,就很好地模拟了实际的摸牌体验,

当然,循环停止后,也可以打印剩下的牌

        System.out.println("剩余的牌");//显示剩余的牌
            System.out.println(cardList);

 最后在创建一个测试类来看看效果是否符合预期

import java.util.List;

public class demo {
    public static void main(String[] args) {
        Cards cards=new Cards();

        List<Card> cardList=cards.buyCards();
        System.out.println("刚开始的牌"+cardList);

        cards.shuffle(cardList);
        System.out.println("洗牌之后"+cardList);

        cards.drawCard(cardList);//摸牌

    }
}

最后的效果便是这般

说到这里,简单的洗牌游戏就被成功实现啦,如果感觉文章对你有所帮助的话,还请点点赞~

期待我们下次相会😉

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

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

相关文章

二、企业级架构之Nginx

一、Nginx的重装与升级 1、为什么需要重装与升级&#xff1a; 在实际业务场景中&#xff0c;需要使用软件新版本的功能、特性&#xff0c;就需要对原有软件进行升级或者重装操作。 Nginx&#xff1a;1.12版本 → 1.16版本 2、Nginx重装&#xff1a; 第一步&#xff1a;停止…

linux操作系统的进程状态

这个博客只是为了自己复习用的&#xff01;&#xff01;&#xff01; 冯诺依曼体系结构 计算机是由一个一个硬件组成的 输入设备&#xff1a;键盘&#xff0c;鼠标&#xff0c;扫描仪&#xff0c;写板等等 中央处理器&#xff08;CPU&#xff09;:含有运算器和控制器等 输出单…

Vue-05

v-model 应用于其他表单元素 常见的表单元素都可以用v-model绑定关联 → 快速获取或设置表单元素的值 它会根据控件类型自动选取正确的方法来更新元素 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name…

树莓派部署yolov5实现目标检测(ubuntu22.04.3)

最近两天搞了一下树莓派部署yolov5&#xff0c;有点难搞&#xff08;这个东西有点老&#xff0c;版本冲突有些包废弃了等等&#xff09; 最后换到ubuntu系统弄了&#xff0c;下面是我的整体步骤&#xff08;建议先使能一下ssh&#xff08;最下面有&#xff09;&#xff0c;结合…

Macbook文件清理软件 Mac电脑清理垃圾文件怎么清理

为了维护Macbook电脑的系统健康&#xff0c;我们需要定期给电脑进行全面清理&#xff0c;清除系统垃圾文件、软件缓存和系统内存。那么好用的Macbook文件清理软件有哪些呢&#xff1f;今天就给大家介绍几款好用的电脑清理软件并介绍Mac电脑清理垃圾文件怎么清理。 一、Macbook…

RPA自动化小红书自动化写文以及发文!

1、视频演示 RPA自动化小红书自动写作发文 2、核心功能点 采集笔记&#xff1a;采集小红书上点赞量大于1000的爆款笔记 下载素材&#xff1a;下载爆款笔记的主图 爆款改写&#xff1a;根据爆款笔记的标题仿写新的标题以及新的文案 自动发布&#xff1a;将爆款笔记发布到小红…

Django之REST Client插件

一、接口测试工具介绍 在开发前后端分离项目时,无论是开发后端,还是前端,基本都是需要测试API接口的内容,而目前我们需要开发遵循RESTFul规范的项目,也是必然的(自己不开发前端页面)。 在网上有很多这样的工具,常用的postman,但还是需要下载安装。在这我们介绍一个VSCod…

【GEE实践应用】GEE下载遥感数据以及下载后在ArcGIS中的常见显示问题处理(以下载哨兵2号数据为例)

本期内容我们使用GEE进行遥感数据的下载&#xff0c;使用的相关代码如下所示&#xff0c;其中table是我们提前导入的下载遥感数据的研究区域的矢量边界数据。 var district table;var dsize district.size(); print(dsize);var district_geometry district.geometry();Map.…

51入门之LED

目录 1.配置文件 2.点亮一个LED 2.1单个端口操作点亮单个LED 2.2整体操作点亮LED 3.LED闪烁 4.LED实现流水灯 4.1使用for循环和移位实现 4.1.1移位操作符 4.1.2使用移位操作和for循环实现 4.2使用移位函数实现LED流水灯 众所周知&#xff0c;任何一个硬件工程师…

go juc 线程中的子类

1.go test() 主死随从 package mainimport ("fmt""strconv""time" )func test() {for i : 1; i < 10; i {fmt.Println("hello " strconv.Itoa(i))//阻塞time.Sleep(time.Second)} } func main() {//开启协程go test()for i : 1; …

GT收发器64B66B协议(2)自定义PHY设计

文章目录 前言一、设计框图二、GT_module三、PHY_module3.1、PHY_tx模块3.2、PHY_rx_bitsync模块3.3、PHY_rx模块 四、上板测试 前言 有了对64B66B协议的认识以及我们之前设计8B10B自定义PHY的经验&#xff0c;本文开始对64B66B自定义PHY的设计 一、设计框图 二、GT_module …

什么是redis缓存的雪崩、穿透以及击穿

缓存雪崩 举个例子&#xff0c;例如在双十一中&#xff0c;一点进去。访问量大&#xff0c;所以它很多数据是放在redis区缓存起来&#xff0c;对应redis的100个key。然后假设设置缓存失效时间是三小时。当双十一期间&#xff0c;购物超过这个三小时之后。这个首页的redis缓存会…

Excel、PowerQuery 和 ChatGPT 终极手册(上)

原文&#xff1a;Ultimate ChatGPT Handbook for Enterprises 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 序言 在不断发展的数据管理和分析领域中&#xff0c;掌握 Excel 的查找功能不仅是一种技能&#xff0c;更是高效数据处理的基石。《使用 Power Query 和 Ch…

Red Hat Enterprise Linux release 8.4安装Jenkins

1. 查看安装 1.1 显示 Linux 系统的详细信息&#xff0c;包括内核版本、操作系统版本和其他相关信息 uname -a1.2 查看 Red Hat Linux 系统的版本 cat /etc/redhat-release # 或者 cat /etc/os-release1.3 查看 JDK 是否安装 java -version #查看安装路径 echo $JAVA_HOME1…

Docker 哲学 - docker swarm

Docker Swarm 模式下的集群管理和服务恢复机制 Docker Swarm 是 Docker 的集群管理和编排功能。在 Swarm 模式下&#xff0c;你可以将多个 Docker 主机组合成一个虚拟主机&#xff0c;称为 Swarm 集群。Swarm 集群由一个或多个管理节点&#xff08;manager nodes&#xff09;和…

前端开发基础(HTML5 + CSS3)【第一篇】:HTML标签之文字排版、图片、链接、音频、视频 涵盖了两个综合案例 做到了基础学得会,实战写的出

点击前往前端开发基础专栏&#xff1a; 文章目录 HTML5 CSS3 开发一、开发环境搭建下载 VS Code1. 2 插件的下载1.3 项目和文件的下载 二、 什么是 HTML2.1 标签的语法2.2 代码演示&#xff1a;2.3 小结 三 、HTML基本骨架3.1 快捷键生成HTML骨架3.2 代码展示3.3 小结 四、标…

【游戏逆向】逆向基础之寄存器和内存

寄存器是中央处理器内的组成部分 它们可用来暂存指令、数据和地址。 具有这样功能还有内存 我们这里说的内存都是指虚拟内存。 寄存器和虚拟内存的主要区别在于它的存储和读取速度更快&#xff0c;那么有的同学会说&#xff0c;那我们全用寄存器就好了&#xff0c;但是&…

NOI - OpenJudge - 2.5基本算法之搜索 - 1490:A Knight‘s Journey - 超详解析(含AC代码)

点赞关注吧~ 1490:A Knights Journey 查看提交统计提问 总时间限制: 1000ms 内存限制: 65536kB 描述 Background The knight is getting bored of seeing the same black and white squares again and again and has decided to make a journey around the world. When…

数据仓库面试总结

文章目录 1.什么是数据仓库&#xff1f;2.ETL是什么&#xff1f;3.数据仓库和数据库的区别&#xff08;OLTP和OLAP的区别&#xff09;4.数据仓库和数据集市的区别5.维度分析5.1 什么是维度&#xff1f;5.2什么是指标&#xff1f; 6.什么是数仓建模&#xff1f;7.事实表7.维度表…

StarRocks实战——华米科技埋点分析平台建设

目录 前言 一、原有方案及其痛点 二、引入StarRocks 三、方案改造 3.1 架构设计 3.2 数据流程 3.3 性能指标 3.4 改造收益 前言 华米科技是一家基于云的健康服务提供商&#xff0c;每天都会有海量的埋点数据&#xff0c;以往基于HBase建设的埋点计算分析项目往往效率上…