动听的洗牌游戏(Java篇ArrayList实操)

本篇会加入个人的所谓‘鱼式疯言’

❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言
而是理解过并总结出来通俗易懂的大白话,
小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的.
🤭🤭🤭可能说的不是那么严谨.但小编初心是能让更多人能接受我们这个概念 !!!
在这里插入图片描述

前言

在上篇文章中我们讲解了 ArrayList 和 顺序表 的实现

但唯一遗憾的是没有说明的具有实际运用,这次小编将带大家运用我们 ArrayList 来演示一下我们的 洗牌游戏

  1. 牌面
  2. 牌组
  3. 洗牌
  4. 抽牌

一. 牌面

public class Card {public  int num;public String color;public Card(int num, String color) {this.num = num;this.color = color;}@Overridepublic String toString() {return "{" ++ num +" , "+color  +'}';}
}

我们将牌分为两者不用的属性: 数字和花色

从中我们就可以得到出 不同的牌面

鱼式疯言

重写 tostring()方法 时,我们可以简单重写即可 💖 💖 💖

比如像小编这样

@Override
public String toString() {return "{" ++ num +" , "+color  +'}';
}

二.牌组

public class Cards {
public String []colors={“♥”,“♣”,“♠”,“♦”};
public List createCards() {
List CardList= new ArrayList();
for (int i = 1; i <= 13; i++) {
for (int j = 0; j < colors.length; j++) {
Card card=new Card(i,colors[j]);
CardList.add(card);
}
}

    return CardList;
}

}

得到我们的牌组后我们就可以 打印其牌组观察效果了

在这里插入图片描述
先说明下我们这个实现的基本框架吧

在这里我们是以 card 为数据类型进行传递,我们只需要 把每一张 card 做好,然后把他都放到 CardList 的这张顺序表中即可,这样就得到我们 整个的牌组

鱼式疯言

从中我们打印的很顺利,主要是依靠我们的 ArrayList 来实现的,但有些细节小编就不得不提了

  1. 实例化 ArrayList 对象时需要注意

List CardList= new ArrayList();

  1. 每张卡牌都依次放入数字和颜色形成

Card card=new Card(i,colors[j]);

三. 洗牌

public class Cards {public String []colors={"♥","♣","♠","♦"};public List<Card> createCards() {List<Card> CardList= new  ArrayList<Card>();for (int i = 1; i <= 13; i++) {for (int j = 0; j < colors.length; j++) {Card card=new Card(i,colors[j]);CardList.add(card);}}return CardList;}public void shuffle(List<Card> CardList) {Random r=new Random();for (int j = CardList.size()-1; j > 0 ; j--) {int i=r.nextInt(j);swapCard(CardList,i,j);}}private void swapCard (List<Card> CardList,int i,int j) {Card tmp=CardList.get(i);CardList.set(i,CardList.get(j));CardList.set(j,tmp);}}

洗牌怎么洗,核心框架是什么
在这里插入图片描述

我们洗牌的还是利用了随机数的生成,讲 i 从后往前走,一直和 i 前面 的牌交换就是我们的洗牌流程

所以最终我们实现了这样的效果出来

在这里插入图片描述

鱼式疯言

细节一:
随机数的生成

Random r=new Random();int i=r.nextInt(j);

我们利用 Random 来new一个对象,然后在nextInt(i) 中传出随机数

原理是当放入 i 时,随机数的范围是 0 ~i-1 之间哦

细节二:
交换卡牌

我们这里要注意是以面向对象的思路,所以要有 取出卡牌和放置卡牌的不同动作

  Card tmp=CardList.get(i);CardList.set(i,CardList.get(j));CardList.set(j,tmp);

以上三行代码可以等效于:

tmp = CardList【i】;

CardList【i】= CardList【j】;

CardList【j】=tmp;

四. 抽牌

我们的抽牌有 两种方式

1. 固定三人抽牌

public  void getCard(List<Card> CaedList) {List<Card> hand1=new ArrayList<>();List<Card> hand2=new ArrayList<>();List<Card> hand3=new ArrayList<>();List<List<Card>> hands=new ArrayList<>();hands.add(hand1);hands.add(hand2);hands.add(hand3);for (int i = 0; i < 5; i++) {for (int j = 0; j < 3; j++) {Card flg=CaedList.remove(0);List<Card> hand =hands.get(j);hand.add(flg);}}System.out.println("第一个得到的牌:"+hand1);System.out.println("第二个得到的牌:"+hand2);System.out.println("第三个得到的牌:"+hand3);}

在这里插入图片描述

最终我们得到的效果就是上面这样的

我们整体的逻辑框架就是实例化出三张手,每张手用 顺序表 hands 来管理, 然后对每张手进行从上抽牌的放入即可

鱼式疯言

这里我唯一的细节就是

  1. 我们需要把每张手进行 hands 的管理的实例化细节
List<Card> hand1=new ArrayList<>();
List<Card> hand2=new ArrayList<>();
List<Card> hand3=new ArrayList<>();List<List<Card>> hands=new ArrayList<>();
hands.add(hand1);
hands.add(hand2);
hands.add(hand3);

定义出手,其次 以每只手的类型为类型进行传入,得到 hands 进行管理

  1. 怎么放细节
    Card flg=CaedList.remove(0);List<Card> hand =hands.get(j);hand.add(flg);

从上抽出,这里的抽出是用 0 直接把第一张牌删掉,然后用个变量来接收,

其次用 j 所以的手中抽取每一只手

最后 flg 放入即可

2. 一人随机抽牌

 public List<Card> getCard(List<Card> CardList) {List<Card> hand=new ArrayList<>();Random r =new Random();for (int i = 0; i < 5; i++) {int j=r.nextInt(CardList.size());Card c=CardList.remove(j);hand.add(c);CardList.add(c);}return hand;}

我们得到的牌就是这样的效果:

在这里插入图片描述

梳理下整体的逻辑框架吧

这里我们用了随机抽牌,只需要把五张牌都抽出放入手上,最终这些牌还得 尾插到牌组后面 ,不造成牌的丢失即可

鱼式疯言

细节注意:

  1. 返回值要小心

public List getCard(List CardList)

  1. 抽取的人数未知,所以我们需要返回拿到的牌,以免牌数不够

CardList.add ( c ) ;

总结

  • 牌面: 熟悉的知晓了定义牌的两个属性
  • 牌组: 讲牌进行整合的一个顺序表,并便于后期的管理调用
  • 洗牌: 随机的理解已经面向对象的交换的本质理解
  • 抽牌: 从两个维度来考虑,灵活的把发牌的灵动性体现出来。

小伙伴都 get 到了吗 💕 💕 💕

如果觉得小编写的还不错的咱可支持 三连 下 (定有回访哦) , 不妥当的咱请评论区 指正

希望我的文章能给各位宝子们带来哪怕一点点的收获就是 小编创作 的最大 动力 💖 💖 💖

在这里插入图片描述

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

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

相关文章

LeetCode - 存在重复元素

219. 存在重复元素 II 这道题可以用两个方法解决。 哈希表 从左到右遍历数组&#xff0c;并将数组的下标存到hash中&#xff0c;在遍历数字的过程中&#xff0c;如果hash中不存在nums[i]&#xff0c;将nums[i]加入到hash当中&#xff0c;若存在&#xff0c;则判断下标之间的关…

C#事件实例详解

一、什么是事件&#xff1f; 在C#中,事件(event)是一种特殊的类成员,它允许类或对象通知其他类或对象发生了某些事情。 从语法上看,事件的声明类似于字段,但它们在功能和行为上有一些重要的区别。 从技术角度来说,事件实际上是一个封装了事件订阅和取消订阅功能的委托字段。…

Python中的数据类型有四类八种如何理解?

在Python中&#xff0c;数据类型大致可以分为四大类&#xff0c;包含了八种基本的数据类型&#xff0c;这些分类有助于理解和使用Python进行编程。这四大类分别是&#xff1a; 数字类型 (Numeric Types): 整型 (int): 表示没有小数部分的整数&#xff0c;可以是正数、负数或零。…

海外媒体发稿:9种高效的媒体套餐内容发稿策略分析-华媒舍

海外媒体发稿&#xff1a;9种高效的媒体套餐内容发稿策略分析高效的媒体发布和营销推广策略对公司、本人的成就尤为重要。下面我们就对于媒体套餐内容发稿营销推广策略开展全面解析&#xff0c;帮助读者掌握并应用这9种合理的思路&#xff0c;进而获得更好的媒体营销效果。 1.媒…

Retelling|Facebook2

录音 Facebook 2 Retelling|Facebook2 复述转写 Hi, Im Helen Campbell, from DJ interpretation, European Commission, Im going to talk about Facebook. You Im sure that you are more familiar with Facebook, a lot, a lot more familiar than I than me. But Ive read…

C语言例4-19:求一元二次方程的解

求一元二次方程的解。 代码如下&#xff1a; //求一元二次方程的解 #include<stdio.h> #include<math.h> int main(void) {float a,b,c,d,x1,x2,p,q;printf("a,b,c?\n");scanf("%f,%f,%f",&a,&b,&c);printf("方程 ");…

智能楼宇3D可视化解决方案

什么是智能楼宇? 智能楼宇是为提高楼宇的使用合理性与效率,配置合适的建筑环境系统与楼宇自动化系统、办公自动化与管理信息系统以及先进的通信系统,并通过结构化综合布线系统集成为智能化系统的大楼。 面临的问题 信息孤岛,无法统一管理 各个子系统独立工作、独立管理,…

每天上万简历,录取不到1%!阿里腾讯的 offer 都给了哪些人?

三月天杨柳醉春烟~正是求职好时节~ 与去年秋招的冷淡不同&#xff0c;今年春招市场放宽了许多&#xff0c;不少企业纷纷抛出橄榄枝&#xff0c;各大厂的只差把“缺人”两个字写在脸上了。 字节跳动技术方向开放数10个类型岗位&#xff0c;研发需求占比60%&#xff0c;非研发新增…

redis关联和非关联

1.1.2.关联和非关联 传统数据库的表与表之间往往存在关联&#xff0c;例如外键&#xff1a; 而非关系型数据库不存在关联关系&#xff0c;要维护关系要么靠代码中的业务逻辑&#xff0c;要么靠数据之间的耦合&#xff1a; {id: 1,name: "张三",orders: [{id: 1,ite…

算法系列--动态规划--⼦数组、⼦串系列(数组中连续的⼀段)(1)

&#x1f495;"我们好像在池塘的水底&#xff0c;从一个月亮走向另一个月亮。"&#x1f495; 作者&#xff1a;Mylvzi 文章主要内容&#xff1a;算法系列–动态规划–⼦数组、⼦串系列&#xff08;数组中连续的⼀段&#xff09;(1) 大家好,今天为大家带来的是算法系…

PPP实验

PPP实验 一.实验思路 1.对接口进行配置IP 2.将R2上面的两个serial接口与R3的两个接口进行链路聚合&#xff0c;然后配置IP 3.在R2&#xff08;验证方&#xff09;上配置PPP chap协议 4.在R1上配置验证用户名 5.要使R3和R2能进行双向chap验证&#xff0c;要在R3上配置ppp chap协…

软件设计师19--文件管理

软件设计师19--文件管理 考点1&#xff1a;文件相关概念例题&#xff1a; 考点2&#xff1a;树形目录结构&#xff08;绝对路径与相对路径&#xff09;例题&#xff1a; 考点3&#xff1a;位示图例题&#xff1a; 考点4&#xff1a;索引文件索引文件结构例题&#xff1a; 考点1…

背包DP模板

01背包 01背包-1 #include <bits/stdc.h> using namespace std;const int N 1e5 10; int n, m, f[N][N], v[N], w[N];int main() {cin >> n >> m;for (int i 1; i < n; i) {cin >> v[i] >> w[i];}for (int i 1; i < n; i) {for (int…

安装element ui失败,解决版本冲突问题

解决方法 降低npm的版本 npm install -g npm6.14.8 不用回退 命令&#xff1a;npm install --legacy-peer-deps element-ui --save

【C++】手撕哈希表的闭散列和开散列

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;手撕哈希表的闭散列和开散列 > 毒鸡汤&#xff1a;谁不是一边受伤&#xff0c;一边学会坚强。 > 专栏选自&#xff1a;C嘎嘎进阶 > 望小伙伴们…

后端代码1

// 新增 public JsonResultVo<?> create(ApiIgnore RequestAttribute(ConstVal.REQ_USER) BaseUser baseUser,RequestBody IUTradeBuyPreserveVo iuTradeBuyPreserveVo) {//权限判断if (!baseCompanyService.dataPermission(baseUser, iuTradeBuyPreserveVo.getCompanyi…

wma怎么转换成mp3?无损转换!

WMA&#xff08;Windows Media Audio&#xff09;文件格式诞生于微软公司的数字音频技术研发。由于其高压缩性能和较好的音质&#xff0c;在推出初期主要用于Windows Media Player等微软产品。然而&#xff0c;随着MP3格式的盛行&#xff0c;WMA的使用范围逐渐受到限制。 MP3文…

pytorch简单的优化问题实战

目录 1. Himmelblau函数2. python画出函数图3. 梯度优化代码 1. Himmelblau函数 如下图&#xff1a; 从图中的碗一样的图中可以看出有4个极值点&#xff0c;那么经过优化后&#xff0c;会有4个结果。 4个点的结果见下图&#xff1a; 2. python画出函数图 3. 梯度优化代码 源…

西圣VS飞利浦VS倍思开放式耳机哪款值得入手?爆款产品无广大测评

在当今这个无线耳机盛行的时代&#xff0c;开放式耳机以其独特的佩戴舒适度和出色的音质体验&#xff0c;逐渐赢得了消费者的青睐&#xff0c;西圣、飞利浦、倍思作为市场上的知名品牌&#xff0c;都推出了各具特色的开放式耳机产品&#xff0c;许多消费者也因此不知道哪款更加…