JavaSE——集合框架二(2/6)-综合案例-斗地主游戏(做牌、洗牌、发牌、排序、看牌)

本文主要是介绍JavaSE——集合框架二(2/6)-综合案例-斗地主游戏(做牌、洗牌、发牌、排序、看牌),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

需求与分析

具体实现

牌类定义

房间类定义

初步测试 

启动游戏

运行案例


需求与分析

需求

  • 总共有54张牌
  • 点数:"3","4","5","6","7","8","9","10","J","Q","K","A","2"
  • 花色:"♠","♥","♣","♦"
  • 大小王:"👲","🃏"
  • 斗地主:发出51张牌,剩下3张作为底牌

分析实现

  • 在启动游戏房间的时候,应该提前准备好54张牌
  • 接着,需要完成洗牌、发牌、对牌排序、看牌

具体实现

牌类定义

package user.Collection;public class Card {private String number;private String color;//每张牌是存在牌值大小的private int size;       //0 1 2 ...public Card() {}public Card(String number, String color, int size) {this.number = number;this.color = color;this.size = size;}public String getNumber() {return number;}public void setNumber(String number) {this.number = number;}public String getColor() {return color;}public void setColor(String color) {this.color = color;}public int getSize() {return size;}public void setSize(int size) {this.size = size;}@Overridepublic String toString() {return number + color;}
}

房间类定义

package user.Collection;import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;public class Room {//首先必须有一副牌private List<Card> allCards = new ArrayList<>();public Room(){//1.做出54张牌,存入到集合allCards//a.所有牌的点数String[] numbers = {"3","4","5","6","7","8","9","10","J","Q","K","A","2"};//b.所有牌的花色String[] colors = {"♠","♥","♣","♦"};int size = 0;       //表示每张牌的牌值大小//c.遍历点数,再遍历花色,组织牌for(String number:numbers){//number = "3"size++; //1 2 3 ......for(String color:colors){//得到一张牌Card d = new Card(number,color,size);allCards.add(d);    //存入牌库}}//单独存入大小王Card d1 = new Card("","🃏",++size);  //小王Card d2 = new Card("","👲",++size); //大王Collections.addAll(allCards,d1,d2);}
}

初步测试 

在Room类中加一下输出语句:(已重写Card类的toString方法)

在主程序中运行:

 

运行结果:

启动游戏

在Room类中编写启动游戏的方法,再调用

    public void start() {//1.洗牌Collections.shuffle(allCards);System.out.println("洗牌后:" + allCards);//2.发牌,发给三个玩家 还是使用List集合List<Card> MegMarch = new ArrayList<>();List<Card> JoMarch = new ArrayList<>();List<Card> BethMarch = new ArrayList<>();//正式发牌给这三个玩家,依次发出51张牌,剩余三张作为底牌for(int i = 0;i < allCards.size();i++){Card c = allCards.get(i);//判断发牌给谁if(i % 3 == 0){//发牌给梅格MegMarch.add(c);}else if(i % 3 == 1){//发牌给乔JoMarch.add(c);}else if(i % 3 == 2){//发牌给贝丝BethMarch.add(c);}}//3.对三个玩家的牌进行排序sortCards(MegMarch);sortCards(JoMarch);sortCards(BethMarch);//4.看牌System.out.println("梅格 :" + MegMarch);System.out.println("乔   :" + JoMarch);System.out.println("贝丝 :" + BethMarch);List<Card> lastThreeCards = allCards.subList(allCards.size() - 3,allCards.size());System.out.println("底牌 :" + lastThreeCards);//假设乔抢到了地主JoMarch.addAll(lastThreeCards);sortCards(JoMarch);System.out.println("乔抢到地主后:" + JoMarch);}private void sortCards(List<Card> cards) {Collections.sort(cards, new Comparator<Card>() {@Overridepublic int compare(Card o1, Card o2) {return o2.getSize() - o1.getSize(); //降序排序}});}

运行案例


END


学习自:黑马程序员——JavaSE课程

这篇关于JavaSE——集合框架二(2/6)-综合案例-斗地主游戏(做牌、洗牌、发牌、排序、看牌)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010079

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D