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. mySQL 5.7版 解决密码登录失败Access denied for user 'root'@'localhost' (us

    mySQL 5.7版 解决密码登录失败Access denied for user 'root'@'localhost' (us             2016-03-05              ...

  2. hibernate 框架搭建

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自 ...

  3. 9 python 数据类型—字典

    字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据.python对key进行哈希函数运算,根据计算的结果决定value的存储地址,所以字典是无序存储的,且key必须是可 ...

  4. linux命令学习笔记(55):traceroute命令

    通过traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径.当然每次数据包 由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不 ...

  5. 【leetcode刷题笔记】Binary Tree Level Order Traversal II

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...

  6. tarjan求割点

    首先给大家一个网址讲的比较细:http://www.cnblogs.com/en-heng/p/4002658.html 如果还有不懂的话,可以回来再看看我的文章; 概念明确: 树边:(在[2]中称为 ...

  7. codevs1060 搞笑世界杯

    题目描述 Description 随着世界杯小组赛的结束,法国,阿根廷等世界强队都纷纷被淘汰,让人心痛不已. 于是有 人组织了一场搞笑世界杯,将这些被淘汰的强队重新组织起来和世界杯一同比赛.你和你的朋 ...

  8. C# Hashtable赋值给另一个Hashtable时

    c#中想将一个hashtable的元素全部给另一个hashbale时, 使用迭代一个一个元素赋值 如: ammus.Clear(); IDictionaryEnumerator ie = _temp. ...

  9. [转]CSS3 Filter的十种特效

    最近到处看到有人在说CSS3的filter一直没有时间自己去测试这效果.今天终于抽出时间学习这个CSS3的Filter.不整不知道呀,一整才让我感到吃惊,太强大了.大家先来看个效果吧: 我想光看上面的 ...

  10. WCF中WcfSvcHost.exe如何禁止自动启动

    今天同事问在一个WCF server的解决方案里调试时如何禁止Server自动启动. 经过调查发现, VS的工具WcfSvcHost会在调试时自动扫描工程里的WCF server, 然后启动起来. 如 ...