Java实现斗地主小游戏
作者:huicooling 发布时间:2021-08-05 19:50:17
标签:java,斗地主
本文实例为大家分享了Java实现斗地主小游戏的具体代码,供大家参考,具体内容如下
原理图:
斗地主过程:
* 1、组合牌
* 2、洗牌
* 3、发牌
* 4、看牌
代码实现:
package itcast.demo6;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
public class DouDiZhu {
public static void main(String[] args) {
//1、组合牌
//创建Map集合,键:编号 值:牌
HashMap<Integer,String> pooker = new HashMap<Integer,String>();
//创建List集合,存储编号
ArrayList<Integer> pookerNumber = new ArrayList<Integer>();
//定义13个点数的数组
String[] numbers = {"2","A","K","Q","J","10","9","8","7","6","5","4","3"};
//定义4个花色组合
String[] colors = {"♠","♣","♥","♦"};
//定义一个整数变量,作为Map的键
int index = 2;
//遍历数组,用花色+点数的组合,存储到Map集合中
for(String number : numbers) {
for(String color : colors) {
pooker.put(index, color + number);
pookerNumber.add(index);
index++;
}
}
//System.out.println(pooker);
//System.out.println(pookerNumber);
//单独存储大王和小王
pooker.put(0, "大王");
pookerNumber.add(0);
pooker.put(1, "小王");
pookerNumber.add(1);
//洗牌,将牌的编号打乱
Collections.shuffle(pookerNumber);
//System.out.println(pookerNumber);
//发牌,将牌编号,发给3个玩家集合+1个底牌集合
ArrayList<Integer> player1 = new ArrayList<Integer>();
ArrayList<Integer> player2 = new ArrayList<Integer>();
ArrayList<Integer> player3 = new ArrayList<Integer>();
ArrayList<Integer> buttom = new ArrayList<Integer>();
//发牌,采用的是集合的索引%3
for(int i = 0; i < pookerNumber.size();i++) {
//现将底牌做好
if(i<3) {
//存到底牌去
buttom.add(pookerNumber.get(i));
//对索引%3判断
}else if(i % 3 == 0) {
//索引上的编号,发给玩家1
player1.add(pookerNumber.get(i));
}else if(i % 3 == 1) {
//发给玩家2
player2.add(pookerNumber.get(i));
}else if(i % 3 == 2) {
//发给玩家3
player3.add(pookerNumber.get(i));
}
}
//对玩家手中的编号进行排序
Collections.sort(player1);
Collections.sort(player2);
Collections.sort(player3);
//看牌,就是将玩家手中的编号,到Map集合中查找,根据键找值
//定义实现方法
look("包身工 ",player1,pooker);
look("清洁工 ",player2,pooker);
look("洗碗工 ",player3,pooker);
look("底牌 ",buttom,pooker);
}
public static void look(String name,ArrayList<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();
}
}
运行结果:
来源:https://blog.csdn.net/weixin_40521823/article/details/84144861


猜你喜欢
- 目录问题:解答方案:总结问题:我遇到了一个有趣的问题,它的代码大概是这样的。List<Func<int>> acti
- 多文件上传就是改良一个方法把MultipartFile类换成CommonsMultipartFile类,因为上传多个文件用数组方式的话Mul
- 目录登陆界面的实现登陆界面代码Login类login的监听类 LoginListener聊天界面运行图Client类代码Server代码登陆
- 大体思路如果发总金额为 m的 n 个红包,先用一个长度为 n的临时数组 a 存放 n个随机双精度小数 ,然后用 sum表示数组
- 1.汉诺塔介绍汉诺塔规则1.有三根杆子A,B,C。A杆上有若干碟子2.每次移动一块碟子,小的只能叠在大的上面3.把所有碟子从A杆全部移到C杆
- 在实际项目中,在处理较大的文件时,常常将文件拆分为多个子文件进行处理,最后再合并这些子文件。下面就为各位介绍下Java中合并多个文件的方法。
- 推荐idea2022最新激活教程:idea2021最新激活方法https://www.jb51.net/article/197138.htm
- 1、每帧检查定义一个时间变量 timer,每帧将此时间减去帧间隔时间 Time.deltaTime,如果小于或者等于零,说明定时器到了,执行
- 1、需求 在Java项目中,需要读取resource资源目录下的文件,以及遍历指定资源目
- 返回值类型:System.Int64表示为 Windows 文件时间的当前 DateTime 对象的值。例如:DateTime.Now.To
- 用Linq从一个集合选取几列得到一个新的集合-可改列名
- Android实现九宫格图案解锁,自带将图案转化成数字密码的功能,代码如下:LockPatternView.javapackage com.
- 继承和多态派生类具有基类所有非私有数据和行为以及新类自己定义的所有其他数据或行为,即子类具有两个有效类型:子类的类型和它继承的基类的类型。对
- 一、实现流程1.注册2.登录3.登录保持【状态续签】二、实现方法项目结构1.引入依赖<!-- spring-web --><
- 打个比方:一个object就像一个大房子,大门永远打开。房子里有很多房间(也就是方法)。这些房间有上锁的(synchronized方法),
- 当我们的软件启动的时候,计算机会分配进程给到我们运行的程序,在进程中包含多个线程用于提高软件运行速度。在android网络请求中,我们知道在
- Spring定时任务无故停止又不报错一开始是使用Spring自带的定时器来配置定时任务的,简单快捷,配置如下:<bean id=&qu
- 我们用React Native 做混合开发的时候免不了要原生和React Native 进行通信交互,这篇文章就是分享原生模块与JS传递数据
- 这是一个android开屏布局的实例,可以用于加载广告图片和倒计时的布局。程序中设置的LayoutParams,划分额外空间比例为6分之5,
- 1 SeekBar简介SeekBar是进度条。我们使用进度条时,可以使用系统默认的进度条;也可以自定义进度条的图片和滑块图片等。2 Seek