本文以java双列集合HashMap为核心实现发牌操作:                               

思路:

1.准备牌:创建一个Map集合,存储牌的索引和组装好的牌

     创建一个list集合,来储存牌的索引。

     定义一个花色数组和牌的点数大小的数组,双重for循环来组装牌,大小王单独存入集合

2.洗牌:Colletions中的shuffle(List)方法来打乱牌的顺序

3.发牌:定义4个集合,存储玩家牌的索引和底牌的索引, 遍历存储牌索引的List集合,获取每一个牌的索引

4.排序:使用Collections中的方法sort(List)默认是升序排序

5.看牌:定义一个lookpoker()方法

代码:

    public static void main(String[] args) {
//存扑克
HashMap<Integer, String> poker = new HashMap<>();
//存扑克牌的索引
ArrayList<Integer> pokerIndex = new ArrayList<>();
//通过循环遍历组装牌;
String[] colors = {"♠","♥","♣","♦"};
String[] numbers = {"A","2","3","4","5","6","7","8","9","10","J","Q","K"};
int index = 0;
poker.put(index, "大王");
pokerIndex.add(index++);
poker.put(index, "小王");
pokerIndex.add(index++);
 //循环嵌套遍历两个数组,组装52张牌,存储到集合中
for (String number : numbers) {
for (String color : colors) {
poker.put(index, color + number);
pokerIndex.add(index++);
}
}
// System.out.println(poker);
      //打乱牌的顺序
Collections.shuffle(pokerIndex);
// System.out.println(pokerIndex);
ArrayList<Integer> play1 = new ArrayList();
ArrayList<Integer> play2 = new ArrayList();
ArrayList<Integer> play3 = new ArrayList();
ArrayList<Integer> dipai = new ArrayList();
for (int i = 0; i < pokerIndex.size(); i++) {
if (i >= 51) {
dipai.add(pokerIndex.get(i));
} else if (i % 3 == 0) {
play1.add(pokerIndex.get(i));
} else if (i % 3 == 1) {
play2.add(pokerIndex.get(i));
} else {
play3.add(pokerIndex.get(i));
}
}       
// 使用Collections中的方法sort(List)默认是升序排序
        Collections.sort(dipai);
Collections.sort(play1);
Collections.sort(play2);
Collections.sort(play3); lookPoker("赌圣", poker, play1);
lookPoker("赌侠", poker, play2);
lookPoker("赌神", poker, play3);
lookPoker("底牌", poker, dipai);
} /*
定义一个看牌的方法,提高代码的复用性
参数:
String name:玩家名称
HashMap<Integer,String> poker:存储牌的poker集合
ArrayList<Integer> list:存储玩家和底牌的List集合
查表法:
遍历玩家或者底牌集合,获取牌的索引
使用牌的索引,去Map集合中,找到对应的牌
*/
public static void lookPoker(String name, HashMap<Integer, String> poker, ArrayList<Integer> list) {
//输出玩家名称,不换行
System.out.print(name + ":");
//遍历玩家或者底牌集合,获取牌的索引
for (Integer key : list) {
//使用牌的索引,去Map集合中,找到对应的牌
String value = poker.get(key);
System.out.print(value + " ");
}
System.out.println();//打印完每一个玩家的牌,换行
}

Java用集合实现斗地主发牌的更多相关文章

  1. java集合--模拟斗地主发牌洗牌

    import java.util.*; /** * @Date: 2020/6/17 19:53 */public class Test04 { public static void main(Str ...

  2. Java基础-集合的嵌套

    Java基础-集合的嵌套 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.静态导入 静态导入是在JDK1.5后的新特性,可以减少开发的代码量,但是实际用处是很一般,静态导入的标准 ...

  3. 使用Java实现简单的斗地主案例

    使用Java实现简单的斗地主案例 案例说明:使用Java实现简单的斗地主洗牌发牌的操作: 具体规则: 共有54张牌,顺序打乱: 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后留三张为底牌(地主牌) ...

  4. 【Java】集合_学习笔记

    一.集合 1.集合类也称容器类,主要负责保存.盛装其他数据. 2.集合可以保存数量不确定的数据,保存具有映射关系的数据(也称关联数组). 3.Java5后提供一些多线程安全的集合类,放在java.ut ...

  5. java的集合框架最全详解

    java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作 ...

  6. 谈谈Java的集合组件

    让我们一起谈谈Java的集合组件 我们在使用Java的时候,都会遇到并使用到Java的集合.在这里通过自己的理解和网上的资源对Java的集合方面的使用做一个简单的讲解和总结. Java主要分为3个集合 ...

  7. java.util 集合框架集合

    java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...

  8. Java基础——集合框架

    Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...

  9. Java学习-集合(转)

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

随机推荐

  1. spring boot 四大组件之Actuator

    执行器(Actuator)的定义 执行器是一个制造业术语,指的是用于移动或控制东西的一个机械装置,一个很小的改变就能让执行器产生大量的运动.An actuator is a manufacturing ...

  2. PHP ftp_get_option() 函数

    定义和用法 The ftp_get_option() 函数返回 FTP 连接的各种运行时选项. 语法 ftp_get_option(ftp_connection,option) 参数 描述 ftp_c ...

  3. Android中attrs.xml文件的使用详解

    $*********************************************************************************************$ 博主推荐 ...

  4. js中浏览器对象BOM

    参考  :  https://www.cnblogs.com/Peng2014/p/4725524.html 1. window对象   https://www.runoob.com/jsref/ob ...

  5. 【Java架构:基础技术】一篇文章搞掂:Eclipse

    Eclipse中使用SVN 1.打开资源库视图 https://www.cnblogs.com/liangguangqiong/p/7965770.html 一.编辑器方面 格式化取消自动换行:打开E ...

  6. H. GSS and Simple Math Problem--“今日头条杯”首届湖北省大学程序设计竞赛(网络同步赛)

    题目描述:链接点此 这套题的github地址(里面包含了数据,题解,现场排名):点此 题目描述 Given n positive integers , your task is to calculat ...

  7. mac 安装 pymssql 报错

    报错信息 _mssql.c:346:10: fatal error: 'sqlfront.h' file not found #include "sqlfront.h" ^~~~~ ...

  8. tp5使用jwt生成token,做api的用户认证

    首先 composer 安装  firebase/php-jwt github:https://github.com/firebase/php-jwt composer require firebas ...

  9. 【SQL】事务回滚

    事务(Transaction)是并发控制的单位,是用户定义的一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位.通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服 ...

  10. Linux apache httpd virtual配置

    必须要关闭 selinux,否则无法访问目录