首先,奉上java集合框架的练习之斗地主洗牌发牌的模拟(初级版)的链接:http://blog.csdn.net/striner/article/details/78489306

初级版只具有洗牌发牌的功能,而玩家拿到手的牌也是乱序排放,此次程序需在初级版的基础上另加扑克牌的排序功能,进行进一步的升级.

注:虽说此次程序是对上一次程序的一个升级,不过不要怕,没看过初级版的人看这篇博客也是完全不会有压力的哦~

老规矩,上步骤分析:步骤的话和初级版一样的哦~   创建一副扑克牌 --> 洗牌 --> 发牌 --> 看牌

那么,问题来了. 要怎样做才可以使得玩家看到的牌都是已经排好序的牌呢?

哈哈,别急别急,听我慢慢道来~

要想使得扑克牌排序,首先你得有个双列集合HashMap<>,给所有的牌排上序并加上索引.再用ArrayList存储索引,之后洗牌的话只需要洗ArrayList<>存储的内容就可以啦.

这样的话ArrayList集合中存的数都是Collections.shuffle(ArrayList list)随机置换(洗牌)过的数.

创建一个TreeSet集合,TreeSet集合具有自动排序功能,用来存储玩家所拿到的牌.

将洗过后的牌发给三个玩家并留三张底牌.而通过索引根据之前创建的HashMap集合找到的相对应的扑克牌集就是玩家最终拿到手的牌哦~

而至于为什么要用HashMap集合来存储索引和扑克牌,那是因为在双列集合中HashMap集合的效率最高哦~

emmmm.接下来,二话不说,上代码~~

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.TreeSet;public class Poker_Collections_shuffle_2 {public static void main(String[] args) {/*创建一副扑克*/String[] num = {"3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "1", "2"};String[] color = {"黑桃", "红桃", "梅花", "方块"};int index = 0;     // 牌的下标HashMap<Integer, String> hm = new HashMap<>();ArrayList<Integer> list = new ArrayList<>();for (String s1 : num) {for (String s2 : color) {hm.put(index, s2.concat(s1));      // 存储前52张牌  index: 0 ~ 51index++;list.add(index);}}hm.put(index++, "小王");       // 存储"小王"   index为52list.add(index);hm.put(index, "大王");         // 存储"大王"   index为53list.add(index);/*洗牌*/Collections.shuffle(list);/*发牌*/TreeSet<Integer> player1 = new TreeSet<>();TreeSet<Integer> player2 = new TreeSet<>();TreeSet<Integer> myself = new TreeSet<>();TreeSet<Integer> dipai = new TreeSet<>();for (int i = 0; i < hm.size(); i++) {if (i >= hm.size() - 3) {dipai.add(list.get(i));      // index = list.get(i)} else if (i%3 == 0) {player1.add(list.get(i));} else if (i%3 ==1) {player2.add(list.get(i));} else {myself.add(list.get(i));}}/*看牌*/

看牌这里需要定义一个方法,而该方法的作用就是打印指定玩家或者底牌所有的牌.

该方法需要传的值为HashMap<Integer, String> hm, TreeSet<Integer> ts, 和需要查找到玩家String name .

        lookPoker(hm, player1, "plarer1");lookPoker(hm, player2, "plarer2");lookPoker(hm, myself, "myself");lookPoker(hm, dipai, "底牌");}private static void lookPoker(HashMap<Integer, String> hm, TreeSet<Integer> ts, String name) {          // TreeSet<Integer>拿到的是所有的键System.out.print(name + "牌为: ");for (Integer i : ts) {         //  i为ts中每一个键System.out.print(hm.get(i) + " ");}System.out.println();}
}

看完了代码你还有什么疑惑之处吗?有什么不懂之处欢迎评论哦~

最后,再放上代码的运行结果:

查阅相关代码请点击:https://github.com/striner/javaCode/blob/master/Fight%20the%20Landlord_2

喜欢就请点个赞  你们的支持是我最大的动力!

java集合框架的练习之斗地主洗牌发牌的模拟(升级版)相关推荐

  1. java中Map集合、模拟斗地主洗牌发牌、JDK9对集合添加的优化

    1.1 Map集合概述 Map集合概述 Map==>映射(一个对应一个) Map是一个接口,只要实现了该接口的类都是双列集合. 双列集合每次存储元素时都需要存储两个元素,一个元素称为键,一个元素 ...

  2. 模拟斗地主洗牌发牌-JAVA

    1.1案例介绍 按照斗地主的规则,完成洗牌发牌的动作. 具体规则: 1.组装54张扑克牌 2.将54张牌顺序打乱 3.三个玩家参与游戏,三人交替摸牌,,每人17张牌,最后三张留作底牌. 4.查看三人各 ...

  3. Java实现模拟斗地主洗牌发牌

    按照斗地主的规则,完成洗牌发牌看牌的动作.最终结果预计为: 具体规则: 1.组装54张扑克牌 2.将54张扑克牌顺序打乱 3.三个玩家参与游戏,三人交替摸牌,每人17张,最后三张做底牌 4.查看三人手 ...

  4. 斗地主洗牌发牌——排序版

    文章目录 前言 一.知识点 二.使用步骤 2.完整代码 感谢您的阅读,不足之处欢迎指正 前言 Java实现模拟斗地主洗牌发牌操作,留下三张底牌,对发到手的纸牌排序. 一.知识点 主要使用HashMap ...

  5. 【案例 6-4】斗地主洗牌发牌

    [案例介绍] 1.任务描述 斗地主的扑克牌游戏,相信许多人都会玩,本例要求编写一个斗地主的洗牌发牌程序,要求按照斗地主的规则完成洗牌发牌的过程.一副扑克总共有 54 张牌,牌面由花色和数字组成(包括 ...

  6. 【JAVASE】模拟斗地主洗牌发牌

    1.案例介绍 按照斗地主的规则,完成洗牌发牌的动作. 具体规则: 组装54张扑克牌 54张牌顺序打乱 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌. 查看三人各自手中的牌(按照牌的大 ...

  7. java使用集合模拟斗地主洗牌发牌案例

    package com.itheima.模拟斗地主.斗地主版本2;import java.util.ArrayList; import java.util.Collections; import ja ...

  8. 18.集合框架(Map集合,HashMap和Hashtable的区别,Collections(集合工具类),集合练习,模拟斗地主(洗牌,发牌,看牌))

    1.Map集合概述和特点 1.需求:    根据学号获取学生姓名 2.Map接口概述     查看API可以知道:     将键映射到值的对象     一个映射不能包含重复的键     每个键最多只能 ...

  9. java实现斗地主洗牌发牌功能

    设计思路 初始化54张牌 洗牌 发牌 给玩家手牌排序 展示玩家手牌及3张底牌 实现思路 首先是54张牌要选择一种数据结构存放,这里选择List和Map集合都可以,我这里选择的是Map 要区分4种花色, ...

最新文章

  1. 搭建Git服务器教程转载
  2. python类的成员函数_python特殊成员函数
  3. 获取用户的IP地址的三个属性的区别
  4. iOS9 Search API 之 Spotlight
  5. 如何静态添加toolbar到datagrid
  6. 物联网技术的发展历史及关键技术
  7. ssh 连接服务器_使用 SSH Key 访问服务器
  8. 设置了hover伪类中有cursor:hand但是没有效果
  9. Flume数据传输事务分析[转]
  10. 由PPPOE看Linux网络协议栈的实现
  11. linux实用的日志分析脚本
  12. 在不同应用场景中,我们该如何进行测试呢?
  13. ENVI入门系列教程---一、数据预处理---1.2基本操作--5.x以后的界面(旧界面)
  14. 如何防止sql注入?防止sql注入方法介绍
  15. [论文笔记] Sigcomm 2018 Elastic Sketch: Adaptive and Fast Network-wide Measurements
  16. 互联网晚报 | 12月25日 星期六 | 小米首款自研充电芯片澎湃P1官宣;抖音电商启动“冬季山货节”;全国首批“千兆城市”出炉...
  17. The current process just got forked. Disabling parallelism to avoid deadlocks.To disable this warnin
  18. import torchvision报错,UserWarning: Failed to load image Python extension: Could not find module ‘C:\U
  19. Hadoop生态系统完整组件及其在架构中的作用
  20. 认识计算机教案模板表格,word表格制作教学设计范文

热门文章

  1. ssm基于jsp的在线点餐系统 毕业设计源码111016
  2. mysql 破坏索引_mysql表索引被破坏的问题及解决
  3. 计算机方向 会议级别
  4. STM8/STM32 SPI模式的MAX7456代码
  5. 基于PHP+Html+mysql的客户关系管理CRM系统 文档+项目源码及数据库文件
  6. Excel 提取工作表名
  7. Sketch占满MacBook200G硬盘的解决方法
  8. 一个中专生在华为面试的真实经历!
  9. hdu 3853 LOOPS
  10. PDF文件加密了怎么办?