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. php将一个二维数组按照某个字段值合并成一维数组,如果有重复则将重复的合并成二维数组

    版权声明:本文为博主原创文章,未经博主允许不得转载. 最近工作中碰到一个问题,用PHP将一个二维数组按照二维数组中的各个项中的某个特定字段值合并成一维数组,如果有重复则将重复的合并成二维数组,生成的二 ...

  2. hibernate复习第(一)天

    首先导入jar. 这个版本是3.2.5 开发流程: 1.由Domain object ->mapping ->db (官方推荐) 2.由DB开始,使用工具生成mapping和Domain ...

  3. codeforces 631B B. Print Check

    B. Print Check time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  4. 大白话AOP

    工作一年多后, 第二次看了韩顺平老师讲的AOP (11年的Spring 教学视频) AOP还是比较艰涩的东西. 从刚开始 碰Java项目去找书看开始, 到学了拦截器知道AOP就是处理事务, 日志, 安 ...

  5. [基本操作]线段树分治和动态dp

    不知道为什么要把这两个没什么关系的算法放到一起写...可能是都很黑科技? 1.线段树分治 例题:bzoj4026 二分图 给你一个图,资瓷加一条边,删一条边,询问当前图是不是二分图 如果用 LCT 的 ...

  6. bzoj 4540: [Hnoi2016]序列 莫队

    题目: 给定长度为n的序列:a1,a2,-,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,-,ar- 1,ar.若1≤l≤s≤t≤r≤n,则称a[s:t]是a ...

  7. 【LeetCode】020. Valid Parentheses

    Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ...

  8. Tangent space(切线空间)

    https://en.wikipedia.org/wiki/Frenet%E2%80%93Serret_formulas The tangent, normal, and binormal unit ...

  9. 转载 : 10大H5前端框架

    原文作者: http://www.cnblogs.com/kingboy2008/p/5261771.html 作为一名做为在前端死缠烂打6年并且懒到不行的攻城士,这几年我还是阅过很多同门从知名到很知 ...

  10. Python xlrd、xlwt、xlutils修改Excel文件-OK

    一.xlrd读取excel 这里介绍一个不错的包xlrs,可以工作在任何平台.这也就意味着你可以在Linux下读取Excel文件. 首先,打开workbook:    import xlrdwb = ...