热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

首先,奉上java集合框架的练习之斗地主洗牌发牌的模拟(初级版)的链接:http:blog.csdn.netstrinerarticledetails78489306初级版只具有洗牌发牌

首先,奉上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 hm = new HashMap<>();
ArrayList list = new ArrayList<>();
for (String s1 : num) {
for (String s2 : color) {
hm.put(index, s2.concat(s1)); // 存储前52张牌 index: 0 ~ 51
index++;
list.add(index);
}
}
hm.put(index++, "小王"); // 存储"小王" index为52
list.add(index);
hm.put(index, "大王"); // 存储"大王" index为53
list.add(index);

/*洗牌*/
Collections.shuffle(list);

/*发牌*/
TreeSet player1 = new TreeSet<>();
TreeSet player2 = new TreeSet<>();
TreeSet myself = new TreeSet<>();
TreeSet dipai = new TreeSet<>();

for (int i = 0; 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 hm, TreeSet ts, 和需要查找到玩家String name .

      
        lookPoker(hm, player1, "plarer1");
lookPoker(hm, player2, "plarer2");
lookPoker(hm, myself, "myself");
lookPoker(hm, dipai, "底牌");
}

private static void lookPoker(HashMap hm, TreeSet ts, String name) { // TreeSet拿到的是所有的键
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

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








推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文介绍了一个适用于PHP应用快速接入TRX和TRC20数字资产的开发包,该开发包支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。提供的功能包括生成地址、验证地址、查询余额、交易转账、查询最新区块和查询交易信息等。详细信息可参考tron-php的Github地址:https://github.com/Fenguoz/tron-php。 ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
author-avatar
迷路
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有