规则:

1.54张扑克牌,有花色

2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌

3.看牌:按大小王2A....43的序排列打印

示例:

package demo;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; public class DouDiZhu {
public static void main(String[] args) {
// 创建Map集合,键是编号,值是牌
HashMap<Integer, String> pooker = new HashMap<Integer, String>();
// List集合存储编号
// 用List集合原因:可以调用排序方法
ArrayList<Integer> pookerNumber = new ArrayList<Integer>();
// 由于13个点数恒定,定义数组
String[] numbers = { "2", "A", "K", "Q", "J", "10", "9", "8", "7", "6", "5", "4", "3" };
// 花色恒定,定义数组
String[] colors = { "♠", "♥", "♣", "♦" };
// 定义整数变量,作为键,0和1留给大小王
int index = 2;
// 遍历数组,存入Map集合
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); // 发牌
// 三个玩家和底牌
ArrayList<Integer> player1 = new ArrayList<Integer>();
ArrayList<Integer> player2 = new ArrayList<Integer>();
ArrayList<Integer> player3 = new ArrayList<Integer>();
ArrayList<Integer> dipai = new ArrayList<Integer>();
// 每张依次发到三个玩家
for (int i = 0; i < pookerNumber.size(); i++) {
// 先将底牌做好
if (i < 3) {
dipai.add(pookerNumber.get(i));
}
// 依次给每个玩家发牌
else if (i % 3 == 0) {
player1.add(pookerNumber.get(i));
} else if (i % 3 == 1) {
player2.add(pookerNumber.get(i));
} else if (i % 3 == 2) {
player3.add(pookerNumber.get(i));
}
}
// 对玩家手中的牌排序
Collections.sort(player1);
Collections.sort(player2);
Collections.sort(player3);
// 看牌,根据键找值
look("玩家1", player1, pooker);
look("玩家2", player2, pooker);
look("玩家3", player3, pooker);
look("底牌", dipai, pooker);
} public static void look(String name, ArrayList<Integer> player, HashMap<Integer, String> pooker) {
System.out.print(name + ":");
for (Integer key : player) {
String value = pooker.get(key);
System.out.print(" " + value);
}
System.out.println();
}
}

效果:

每次的结果都不一致:

有兴趣的朋友可以根据斗地主的规则继续开发下去,做成一个简易的斗地主游戏

Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)的更多相关文章

  1. 【Java学习笔记】<集合框架>定义功能去除ArrayList中的重复元素

    import java.util.ArrayList; import java.util.Iterator; import cn.itcast.p1.bean.Person; public class ...

  2. 【Java学习笔记】<集合框架>对字符串进行长度排序

    package 测试; import java.util.Comparator; public class ComparatorByLength implements Comparator { //定 ...

  3. 【Java学习笔记】<集合框架>TreeSet,Comparable,Comparator

    public class Person implements Comparable{ private String name; private int age; public Person(){ su ...

  4. Java学习笔记之---集合

    Java学习笔记之---集合 (一)集合框架的体系结构 (二)List(列表) (1)特性 1.List中的元素是有序并且可以重复的,成为序列 2.List可以精确的控制每个元素的插入位置,并且可以删 ...

  5. Java基础学习笔记十七 集合框架(三)之Map

    Map接口 通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同,如下图. Collection中的集合,元素是孤立存在的(理解为单身),向集合中存 ...

  6. JavaSE 学习笔记之集合框架(十八)

    集合框架:,用于存储数据的容器. 特点: 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合和数组的区 ...

  7. Java学习笔记之集合

    集合(Collection)(掌握) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组而数组的长度固定 ...

  8. java学习笔记之集合家族2

    集合体系 一.数据结构 List集合储存数据结构 <1>堆栈结构 特点:先进后出 <2>队列结构 特点:先进先出 <3>数组结构 特点:查询快,增删慢 <4& ...

  9. 【原】Java学习笔记026 - 集合

    package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:从三国演义中 ...

随机推荐

  1. js方法用来获取路径传参上所带的参数

    //js方法用来获取路径传参上所带的参数 function GetQueryString(param) { var reg = new RegExp("(^|&)" + p ...

  2. Controller层aop

    利用@Around通知修改Controller的返回值 自定义一个注解@OperationBtn 在切入点Controller上加上自定义注解 接下来就是重点了,AspectJ写切面类,对该Contr ...

  3. ubuntu环境下,ubuntu16.04装机到nvdia显卡驱动安装、cuda8安装、cudnn安装

    首先是安装ubuntu16.04 A.制作u盘启动盘(提前准备好.ios文件): 1.安装u盘制作工具unetbootinsudo apt-get install unetbootin2.格式化u盘s ...

  4. FloatingActionButton FAB 悬浮按钮

    FloatingActionButton简称FAB,这是一种比较美观的按钮: 1.使用前: FAB代表一个App或一个页面中最主要的操作,如果一个App的每个页面都有FAB,则通常表示该App最主要的 ...

  5. java通过年月得到该月每一天的日期

    public static List<String> getDayByMonth(int yearParam,int monthParam){ List<String> lis ...

  6. 标志寄存器在Debug中的表示

    在Debug中,标志寄存器是按照有意义的各个标志位单独表示的. 下面列出Debug对我们已知的标志位的表示.

  7. 字符串转码中文乱码问题的进一步理解 UTF-8 GBK转码

    首先 要明确指出一点: 编码方式是针对字符串转换之后的字节数组的,字符串并没有编码方式的概念,因为字符串不管是在什么编码页面下他只是一个对象,他只有字符的概念,不管页面编码方式是什么,他始终都是那几个 ...

  8. Sass入门及知识点整理

    Sass 快速入门 | SASS 中文网 文档链接:https://www.sasscss.com/getting-started/ 前言 之前整理了一篇关于Less的,现在就来整理一下关于Sass的 ...

  9. 拜托!面试请不要再问我Spring Cloud底层原理[z]

    [z]https://juejin.im/post/5be13b83f265da6116393fc7 拜托!面试请不要再问我Spring Cloud底层原理 欢迎关注微信公众号:石杉的架构笔记(id: ...

  10. Heartbleed心脏出血漏洞原理分析

    Heartbleed心脏出血漏洞原理分析 2017年01月14日 18:14:25 阅读数:2718 1. 概述    OpenSSL在实现TLS和DTLS的心跳处理逻辑时,存在编码缺陷.OpenSS ...