import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List; public class DouDiZhu {
public static void main(String[] args) {
//牌谱
HashMap<Integer, String> pooker = new HashMap<>();
//List:store number
List<Integer> pookernumber = new ArrayList<>();
//定义出13个点数的数组
String[] numbers = {"2", "A", "K", "Q", "J", "10", "9", "8", "7", "6", "5", "4", "3"};
//定义4个花色数组
String[] colors = {"♠", "♥", "♣", "♦"};
//
int index = 2;
for (String number : numbers) {
for (String color : colors) {
pooker.put(index, color + number);
pookernumber.add(index);
index++;
}
}
//存储大王,和小王
pooker.put(0, "大王");
pookernumber.add(0);
pooker.put(1, "小王");
pookernumber.add(1); //打乱编号
Collections.shuffle(pookernumber);
//发牌:三个玩家和底牌
List<Integer> player1 = new ArrayList<>();
List<Integer> player2 = new ArrayList<>();
List<Integer> player3 = new ArrayList<>();
List<Integer> bottom = new ArrayList<>();
for (int i = 0; i < pookernumber.size(); i++) {
if(i<17){
player1.add(pookernumber.get(i));
}else if(i<17+17){
player2.add(pookernumber.get(i));
}else if(i<17+17+17){
player3.add(pookernumber.get(i));
}else {
bottom.add(pookernumber.get(i));
}
}
//player number sort
Collections.sort(player1);
Collections.sort(player2);
Collections.sort(player3);
//show
look("player1",player1,pooker);
look("player2",player2,pooker);
look("player3",player3,pooker);
look("bottom",bottom,pooker);
}
public static void look(String name,List<Integer> player,HashMap<Integer,String> pooker){
//遍历ArrayList集合,获取元素,作为键,到集合Map中找值
System.out.print(name+" ");
for(Integer key : player){
String value = pooker.get(key);
System.out.print(value+" ");
}
System.out.println();
}
}

多次运行测试一下:

player1 ♠2 ♥2 ♥A ♣A ♦A ♠Q ♣Q ♦Q ♥J ♣9 ♣8 ♥7 ♠6 ♠5 ♣5 ♠4 ♦3
player2 大王 ♦2 ♠K ♦K ♠J ♣J ♦J ♦10 ♥9 ♦8 ♣6 ♦6 ♥4 ♣4 ♦4 ♠3 ♥3
player3 小王 ♣2 ♠A ♥K ♣K ♥Q ♥10 ♠9 ♦9 ♠8 ♥8 ♣7 ♦7 ♥6 ♥5 ♦5 ♣3
bottom ♣10 ♠7 ♠10
player1 小王 ♠2 ♥2 ♣2 ♠A ♣K ♦Q ♥J ♥9 ♣9 ♦9 ♠8 ♣8 ♣7 ♠4 ♣3 ♦3
player2 ♦2 ♥K ♦K ♠Q ♦J ♣10 ♦10 ♠9 ♥8 ♦8 ♥6 ♣6 ♦6 ♠5 ♥4 ♠3 ♥3
player3 大王 ♥A ♣A ♦A ♠K ♥Q ♠J ♣J ♥10 ♠7 ♥7 ♦7 ♠6 ♥5 ♣5 ♣4 ♦4
bottom ♠10 ♦5 ♣Q
player1 ♥2 ♦2 ♥A ♦A ♠K ♣J ♦J ♠10 ♣10 ♠9 ♣8 ♦8 ♣7 ♣6 ♥4 ♣4 ♦4
player2 大王 小王 ♠2 ♣K ♦K ♠Q ♣Q ♥10 ♥9 ♦9 ♥8 ♥7 ♠6 ♥6 ♣5 ♠3 ♣3
player3 ♣2 ♠A ♣A ♥K ♥Q ♦Q ♠J ♥J ♦10 ♣9 ♠7 ♦7 ♦6 ♥5 ♠4 ♥3 ♦3
bottom ♦5 ♠8 ♠5

Java——利用集合类实现简单斗地主发牌的更多相关文章

  1. Java之集合类

    出处:http://blog.csdn.net/zhangerqing 一.集合类简介 数组是很常用的一种的数据结构,我们用它可以满足很多的功能,但是,有时我们会遇到如下这样的问题: 1.我们需要该容 ...

  2. Java利用Preferences设置个人偏好

    Java利用Preferences设置个人偏好 Preferences的中文意思即偏好或喜好的意思,也就是说同一个程序在每次运行完后,可以通过Preferences来记录用户的偏好,下次启动时,程序会 ...

  3. Java的集合类

    转自:Q.Mr的博客 http://www.cnblogs.com/zrtqsk/p/3472258.html (本人第一次写博客,部分内容有参照李刚老师的疯狂java系列图书,如有遗漏错误,请多指教 ...

  4. java 利用spring JavaMailSenderImpl发送邮件,支持普通文本、附件、html、velocity模板

    java 利用spring JavaMailSenderImpl发送邮件,支持普通文本.附件.html.velocity模板 博客分类: Java Spring   本文主要介绍利用JavaMailS ...

  5. Unity NGUI 网络斗地主 -发牌 脚本交互

    Unity NGUI 网络斗地主 -发牌 脚本交互 @By 灰太龙 Unity4.2.1f4 NGUI 3.0.4 本篇说的问题是脚本与控件的交互! 现在对界面进行了改进,先看副图! 1.制作发牌效果 ...

  6. 利用LinkedHashMap实现简单的缓存

    update1:第二个实现,读操作不必要采用独占锁,缓存显然是读多于写,读的时候一开始用独占锁是考虑到要递增计数和更新时间戳要加锁,不过这两个变量都是采用原子变量,因此也不必采用独占锁,修改为读写锁. ...

  7. 首先java中集合类主要有两大分支

    本文仅分析部分原理和集合类的特点,不分析源码,旨在对java的集合类有一个整体的认识,理解各个不同类的关联和区别,让大家在不同的环境下学会选择不同的类来处理. Java中的集合类包含的内容很多而且很重 ...

  8. 【转载】 java利用snmp4j包来读取snmp协议数据(Manager端)

    https://www.cnblogs.com/xdp-gacl/p/4187089.html http://doc.okbase.net/yuanfy008/archive/265663.html ...

  9. Java利用poi生成word(包含插入图片,动态表格,行合并)

    转(小改): Java利用poi生成word(包含插入图片,动态表格,行合并) 2018年12月20日 09:06:51 wjw_11093010 阅读数:70 Java利用poi生成word(包含插 ...

随机推荐

  1. Struts2 第一个入门小案例

    1.加载类库 2 配置web.xml文件 3.开发视图层 4.开发控制层Action 5.配置struts.xml 6.部署运行

  2. UI层自动化测试介绍

    UI指的是用户可以用肉眼可以看到的页面. UI层自动化测试的原理.不论是web端还是移动端,原理都是一样的,就是基于页面元素的识别和定位来进行模拟用户行为. 首先识别到某个元素,比如一个按钮,然后定义 ...

  3. NYOJ-括号配对问题--------待解决,RE

    描述 现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0<N<=100),表示有N组测试数据.后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S的 ...

  4. 每天一个linux命令(7):rmdir命令

    版权声明更新:2017-05-11博主:LuckyAlan联系:liuwenvip163@163.com声明:吃水不忘挖井人,转载请注明出处! 1 文章介绍 本文介绍了Linux下面的rmdir命令. ...

  5. ES+open-falcon之报警自动发送请求信息

    当我们监控nginx的状态码出现错误状态码的时候, 一般的处理方法是通过kibana查询是哪个接口导致从而确定是哪个服务,再进一步登录业务机器查询业务日志确定原因. 我们现在要做的事情就是将 人为的通 ...

  6. ACM学习历程—HDU 5025 Saving Tang Monk(广州赛区网赛)(bfs)

    Problem Description <Journey to the West>(also <Monkey>) is one of the Four Great Classi ...

  7. Mathf.Sin正弦

    输入参数是弧度 Mathf.Sin   public static float Sin(float f); Parameters Description Returns the sine of ang ...

  8. Ubuntu中Could not get lock /var/lib/dpkg/lock

    找出所有的 apt 以及 apt-get 进程: ps -A | grep apt-get 杀死进程: processnumbe 删除锁定文件: rm /var/lib/dpkg/loc 之后像下面这 ...

  9. RS-485收发的零延时转换电路

    转自:http://www.dzsc.com/data/html/2007-5-28/41097.html RS-485是一种基于差分信号传送的串行通信链路层协议.它解决了RS-232协议传输距离太近 ...

  10. 修改sharepoint列表样式

    1.将sharepoint 的样式修改为阴影 2.用designer打开列表的AllItems.aspx文件,将下面的样式拷贝到里面     <style type="text/css ...