Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)
规则:
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(集合框架八:综合案例:模拟斗地主的洗牌发牌)的更多相关文章
- 【Java学习笔记】<集合框架>定义功能去除ArrayList中的重复元素
import java.util.ArrayList; import java.util.Iterator; import cn.itcast.p1.bean.Person; public class ...
- 【Java学习笔记】<集合框架>对字符串进行长度排序
package 测试; import java.util.Comparator; public class ComparatorByLength implements Comparator { //定 ...
- 【Java学习笔记】<集合框架>TreeSet,Comparable,Comparator
public class Person implements Comparable{ private String name; private int age; public Person(){ su ...
- Java学习笔记之---集合
Java学习笔记之---集合 (一)集合框架的体系结构 (二)List(列表) (1)特性 1.List中的元素是有序并且可以重复的,成为序列 2.List可以精确的控制每个元素的插入位置,并且可以删 ...
- Java基础学习笔记十七 集合框架(三)之Map
Map接口 通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同,如下图. Collection中的集合,元素是孤立存在的(理解为单身),向集合中存 ...
- JavaSE 学习笔记之集合框架(十八)
集合框架:,用于存储数据的容器. 特点: 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合和数组的区 ...
- Java学习笔记之集合
集合(Collection)(掌握) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组而数组的长度固定 ...
- java学习笔记之集合家族2
集合体系 一.数据结构 List集合储存数据结构 <1>堆栈结构 特点:先进后出 <2>队列结构 特点:先进先出 <3>数组结构 特点:查询快,增删慢 <4& ...
- 【原】Java学习笔记026 - 集合
package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:从三国演义中 ...
随机推荐
- SQL Server与MySQL在“存在则更新,不存在则插入”并发处理上的一些差异。
“存在则更新,不存在则插入的逻辑”并发情况下的处理 在sqlserver中: 在sqlserver中,是通过可序列化隔离级别+排它锁的方式来锁定一个范围来实现的当前锁定一个不存在的记录的时候,sqls ...
- 关于$.ajax同步和异步的问题和提交后台的一些问题。
经常有人ajax函数外,定义一个全局变量,并且在返回函数取出一个值用作判断条件,但是这一条件常常失效. var OnOff=0; var checkPhone = function() { var p ...
- cmake 指定连接的opencv版本
我们通常需要使用不同版本的opencv,这时候如果用cmake构建工程,直接指定本地编译好的路径就可以,在CMakeLists.txt中添加: set(OpenCV_DIR "/xxx/wo ...
- k8s之配置flanneld网络
Flannel是Overlay网络的一种,也是将源数据包封装在另一种网络包里面进行路由转发和通信,目前已经支持UDP.VXLAN.AWS VPC和GCE路由等数据转发方式. Flannel通过给每台宿 ...
- Codeforces Round #439 C. The Intriguing Obsession
题意:给你三种不同颜色的点,每种若干(小于5000),在这些点中连线,要求同色的点的最短路大于等于3或者不连通,求有多少种连法. Examples Input 1 1 1 Output 8 Input ...
- jstl标准标签库 常用标签
JSTL(JSP Standard Tag Library)标准标签库: 1, 核心标签(最常用, 最重要的) 表达式控制标签 out 输出常量 value---直接赋值 输出变量 default-- ...
- JavaScript实现观察者模式
首先: 观察者模式是软件设计模式的一种,它
- oracle 查询索引和主键
ORACLE: 1.查主键名称: select * from user_constraints where table_name = 'AAA' and constraint_type ='P'; 查 ...
- python note 03 切片及对字符串操作
1.计算 1 - 2 + 3 ... + 99 中除了88以外的数之和 i = 1 sum = 0 while i < 100 : if i == 88 : i = i + 1 continue ...
- Sass入门及知识点整理
Sass 快速入门 | SASS 中文网 文档链接:https://www.sasscss.com/getting-started/ 前言 之前整理了一篇关于Less的,现在就来整理一下关于Sass的 ...