java实现简单斗地主(看牌排序)
作者:Dr_W 发布时间:2023-09-12 14:42:40
标签:java,斗地主
本文实例为大家分享了java实现简单斗地主的具体代码,供大家参考,具体内容如下
第一种方法
/**
* @param args
*/
/**
* 项目编码格式:
* 1.GBK:只支持简体中文
* 2.GB2312:支持简体和繁体
* 3.UTF-8:国际通用的编码格式
*
* 模拟实现斗地主发牌的过程实现步骤
* 1.准备一副扑克牌
* a.定义一个Map集合用来存放54张扑克 map的key(下标)对应的是map的值(扑克)
* b.定义一个list集合 用来保存map集合的key(map集合的key就对应map集合的值)
* c.定义一个String类型的数组 用来构建牌的花色[♥,♠,♦,♣]
* d.定义一个String的数组 用来保存扑克具体的值[3,4,5,6,7,8,9,10,J,Q,K,A,2]
* e.把大王和小王添加到Map集合中
* 2.洗牌
* 通过集合的一个操作类Collections提供的一个相关方法实现洗牌的操作
* 3.发牌的过程
* a.定义三个玩家和一个接收底牌的集合容器
* b.遍历ArrayList集合中 如何实现每个玩家轮流拿牌
* 【J,Q,9,10,2,A........Q】
* 【0,1,2,3,4,5.........53】
* 发牌思路分析:
* 如果当前的下标大于等于51 剩下的牌留作底牌
* 可以使用下标对3求余数 0%3 = 0 把J给玩家1 1%3 = 1 把Q给玩家2 2%3 = 2 把9给玩家3 3%3 =0 把10给玩家1 4%3 = 1
* 4.排序
* 5.看牌
* 实现每个玩家的牌输出展现
*
*/
/*
* 思路总结:
* 根据下标排序,所以用map,key就是下标,对应值就是扑克(花色+数)
* 洗牌的shuffle,排序的sort方法只能对list管用
* 所以用list集合盛放key,对key洗牌,然后对key排序
* 用key去map里去对应的值
* */
public static void main(String[] args) {
Map<Integer,String> poker = new HashMap<Integer,String>();
List<Integer> keys = new ArrayList<Integer>();
String[] colors = {"♠","♥","♦","♣"};
String[] values = {"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
int index = 0;
for(String v : values){ //外层循环数,内层循环花色
for(String c : colors){
poker.put(index,c+v); //向map里添加key和值
keys.add(index); //将key添加到list里,便于排序
index++;
}
}
poker.put(index, "小王");
keys.add(index);
index++;
poker.put(index,"大王");
keys.add(index);
//洗牌
Collections.shuffle(keys);
//分牌
List<Integer> player01 = new ArrayList<Integer>(); //创建玩家和底牌集合,专门盛key,根据key去map里去值
List<Integer> player02 = new ArrayList<Integer>();
List<Integer> player03 = new ArrayList<Integer>();
List<Integer> dipai = new ArrayList<Integer>();
for(int i=0; i<keys.size(); i++){ //循环遍历盛key的list集合
if(i>=51){
dipai.add(keys.get(i));
}else if(i%3==0){
player01.add(keys.get(i));
}else if(i%3==1){
player02.add(keys.get(i));
}else if(i%3==2){
player03.add(keys.get(i));
}
}
//针对玩家和底牌排序
player01.addAll(dipai);
Collections.sort(player01);
Collections.sort(player02);
Collections.sort(player03);
Collections.sort(dipai);
System.out.println("玩家一(地主):");
for(Integer key : player01){
System.out.print(poker.get(key)+" ");
}
System.out.println("\n玩家二:");
for(Integer key : player02){
System.out.print(poker.get(key)+" ");
}
System.out.println("\n玩家三:");
for(Integer key : player03){
System.out.print(poker.get(key)+" ");
}
System.out.println("\n底牌:");
for(Integer key : dipai){
System.out.print(poker.get(key)+" ");
}
}
第二种方法
public static void main(String[] args) {
//保存编号和扑克牌的对应关系
HashMap<Integer,String> poker = new HashMap<Integer,String>();
//保存扑克牌的编号
List<Integer> list = new ArrayList<Integer>();
String[] colors = {"♥","♠","♦","♣"};
String[] values = {"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
//把这两个字符串放进HashMap集合中(拼接一起 花色+牌号)同时给每个放进去牌进行编码0--52并存储
int count = 0;
for(String v : values){
for(String color : colors){
//拼接
String pk = color.concat(v);
//把编码和牌存储到HashMap中
poker.put(count, pk);
//把编码存到ArrayList中
list.add(count);
count ++;
}
}
poker.put(count, "小王");
list.add(count);
count++;
poker.put(count, "大王");
list.add(count);
// for(Integer i :list){
// System.out.print(i+" ");
// }
Collections.shuffle(list);
TreeSet<Integer> player01 = new TreeSet<Integer>();
TreeSet<Integer> player02 = new TreeSet<Integer>();
TreeSet<Integer> player03 = new TreeSet<Integer>();
TreeSet<Integer> dipai = new TreeSet<Integer>();
for(int i=0; i<list.size(); i++){
if(i>=51){
dipai.add(list.get(i));
}
else if(i%3 == 0){
player01.add(list.get(i));
}
else if(i%3 == 1){
player02.add(list.get(i));
}
else if(i%3 == 2){
player03.add(list.get(i));
}
}
mingpai("玩家一",player01,poker);
mingpai("玩家二",player02,poker);
mingpai("玩家三",player03,poker);
mingpai("底牌",dipai,poker);
}
//参数列表:String name(玩家名字) ; TreeSet<Integer> i(牌的编号) ; HashMap<Integer,String> pai(牌)
public static void mingpai(String name,TreeSet<Integer> i,HashMap<Integer,String> pai){
List<Integer> li = new ArrayList<Integer>();
System.out.println(name+"的牌是:");
for(Integer key : i){
//TreeSet的值就是HashMap的键,所以可以得到对应的值,也就是牌
String result = pai.get(key);
//输出看到的牌
System.out.print(result+" ");
}
System.out.println(" ");
}


猜你喜欢
- 获取方法的相关信息的两种形式反射是一种允许用户获得类信息的C#功能,Type对象映射它代表的底层对象;在.Net 中, 一旦获得了Type对
- 1. Retrofit使用Retrofit是一个现在网络请求框架,先来说一下怎么使用网络权限(添加到AndroidManifest.xml)
- 表达式目录树表达式目录树:语法树,或者说是一种数据结构1.表达式目录树Expression:System.Linq.Expressions;
- 这篇文章主要介绍了如何基于LoadingCache实现Java本地缓存,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学
- 1. 经过简化的Property 早些时候我们这样声明Property private string _myName; public str
- 今天讲一下目前移动领域很常用的技术——二维码。现在大街小巷、各大网站都有二维码的踪迹,不管是IOS、Android、WP都有相关支持的软件。
- 很多主流框架都使用了反射技术.像ssh框架都采用两种技术 xml做配置文件+反射技术.与反射有关的类包.java.lang.reflect.
- BeanUtilsBeanUtils是Apache commens组件里面的成员,由Apache提供的一套开源api,用于简化对javaBe
- 前面关于spring Boot的文章已经介绍了很多了,但是一直都没有涉及到数据库的操作问题,数据库操作当然也是我们在开发中无法回避的问题,那
- APP中可能会遇到一种需求,就是将当前所在位置的坐标传到服务器上,今天我提供三种途径去获取经纬度坐标信息,第一种是通过Android API
- 本文实例讲述了Java实现指定线程执行顺序的三种方式。分享给大家供大家参考,具体如下:方法一:通过共享对象锁加上可见变量来实现。public
- 使用Myeclipse搭建maven项目准备工作安装maven官网下载安装(http://maven.apache.org/)配置环境变量配
- 本文讲述了Android编程之高效开发App的10个建议。分享给大家供大家参考,具体如下:假如要Google Play上做一个最失败的案例,
- 原来的测试类的注解:@RunWith(SpringRunner.class)@SpringBootTest一直没法自动注入,后来在@Spri
- Java裁剪压缩PNG图片,透明背景色变黑import java.awt.Graphics2D;import java.awt.Image;
- PDF文件和图片文件,这是两种完全不一样的格式,可是有的时候这两种格式却是有相互转换的需要,大家在工作中遇到PDF文件转图片文件的问题时是怎
- Android package属性、package name和Application ID三者的联系及区别package属性:在Androi
- android studio版本:2021.2.1例程名称:pravicydialog功能:1、启动app后弹窗隐私协议2、屏蔽返回键3、再
- Dialog和Toast所有人肯定都不会陌生的,这个我们平时用的实在是太多了。而Snackbar是Design Support库中提供的新控
- 前情提要我们上节内容学习了如何创建\注册\读取bean我们发现bean对象操作十分的繁琐!所以我们这个章节,就带大家来了解更加简单的bean