规则:

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. nexus的安装和简介

    下载nexus Nexus 是Maven仓库管理器,通过nexus可以搭建maven仓库,同时nexus还提供强大的仓库管理功能,构件搜索功能等. 下载Nexus, 下载地址:http://www.s ...

  2. Linux网络编程学习(二) ----- 进程控制(第三章)

    1.进程和程序 程序是一个可执行文件,而一个进程是一个执行中的程序实例.一个进程对应于一个程序的执行,进程是动态的,程序是静态的,多个进程可以并发执行同一个程序.比如几个用户可以同时运行一个编辑程序, ...

  3. javascript隐式原型

    上图是js原型关系图. javascript是一种基于对象的编程语言,但它与一般面向对象的编程语言不同,因为它没有class类的概念 什么是原型?? 我们每创建一个函数,它就会自带一个原型函数,这个原 ...

  4. 【原】 The Linux Command Line - Permissions

    id - display user identity chmod - umask -

  5. spring @Scheduled 并发

    一.spring定时任务配置 applicationContext.xml:红色代码部分为需要配置的部分. <?xml version="1.0" encoding=&quo ...

  6. mybatis-generator 覆盖新增XML

    参考文章:https://www.cnblogs.com/xxoome/p/10068780.html 1.添加依赖(版本1.3.7) plugin> <groupId>org.my ...

  7. linux文本格式转换

    问题:在linux环境下面执行SH的可执行文件. -bash: ./start.sh: /bin/sh^M: bad interpreter: No such file or directory 解决 ...

  8. Vue框架H5商城类项目商品详情点击返回弹出推荐商品弹窗的实现方案

    需求场景: 非推荐商品详情页返回的时候弹出弹窗推荐商品,点击弹窗按钮可以直接访问推荐商品: 只有直接进入商品详情页返回才会弹出推荐商品弹窗: 每个用户访问只能弹一次(除非清除缓存). 需求分析: 1. ...

  9. 654. Maximum Binary Tree 最大节点劈开,然后左边、右边排序

    [抄题]: Given an integer array with no duplicates. A maximum tree building on this array is defined as ...

  10. mybatis进阶-5resultMap总结

    resultType: 作用: 将查询结果按照sql列名pojo属性名一致性映射到pojo中. 场合: 常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用re ...