案例说明:使用Java实现简单的斗地主洗牌发牌的操作;

具体规则:

共有54张牌,顺序打乱;

三个玩家参与游戏,三人交替摸牌,每人17张牌,最后留三张为底牌(地主牌)。

具体代码实现步骤:

扑克牌准备操作

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

public class PokerGame {

public static void main(String[] args) {

//定义扑克牌的花色以及数字的数组

String[] flower = {"♥️","♠️","♣️","♦️"};

String[] numbers = {"A","2","3","4","5","6","7","8","9","10","J","Q","K"};

//创建牌组集合

List poker = new ArrayList();

//组合扑克牌样式

//拿出每一个花色,然后跟每一个数字进行结合,储存在牌组中

for (int i = 0; i < flower.length; i++) {

for (int j = 0; j < numbers.length; j++) {

poker.add(flower[i].concat(numbers[j]));

}

}

//添加大小王到牌组集合中

poker.add("大王");

poker.add("小王");

//打印输出所有扑克牌测试

System.out.println(poker);

//定义三个玩家和地主牌的集合

List player1 = new ArrayList();

List player2 = new ArrayList();

List player3 = new ArrayList();

List dizhupai = new ArrayList();

//洗牌操作,使用shuffle方法

Collections.shuffle(poker);

System.out.println(poker); //测试牌有没有被打乱

//发牌操作

for (int k = 0; k

//留出三张牌存到底牌的集合中

if (k > 50) {

dizhupai.add(poker.get(k));

} else if (k % 3 == 0) {

player1.add(poker.get(k));

} else if (k % 3 == 1) {

player2.add(poker.get(k));

} else if (k % 3 == 2) {

player3.add(poker.get(k));

}

}

//最终看牌操作

System.out.println("玩家一的牌"+player1);

System.out.println("玩家二的牌"+player2);

System.out.println("玩家三的牌"+player3);

System.out.println("地主牌"+dizhupai);

}

}

结果展示

玩家一的牌:[♥️9, ♠️A, ♠️5, ♥️A, ♥️2, ♥️10, ♠️7, ♣️J, ♥️3, ♠️2, ♣️5, ♦️2, ♠️6, ♥️7, ♦️K, ♣️9, 大王]

玩家二的牌:[♦️9, ♠️4, ♣️4, ♣️10, ♥️J, ♦️4, ♥️8, ♥️5, ♦️A, ♣️A, ♦️7, ♦️3, ♦️Q, ♣️K, ♥️6, ♣️3, ♠️Q]

玩家三的牌:[♣️Q, ♣️2, ♣️8, ♣️7, ♥️Q, ♦️10, ♠️8, ♣️6, ♥️4, ♠️10, 小王, ♥️K, ♠️3, ♦️8, ♦️6, ♠️K, ♠️J]

地主牌:[♠️9, ♦️5, ♦️J]

实例补充:

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 pooker = new HashMap();

//创建List集合,存储编号

ArrayList pookerNumber = new ArrayList();

//定义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 player1 = new ArrayList();

ArrayList player2 = new ArrayList();

ArrayList player3 = new ArrayList();

ArrayList buttom = new ArrayList();

//发牌,采用的是集合的索引%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 player,HashMap pooker) {

//遍历ArrayList集合,获取元素,作为键,到集合Map中找值

System.out.print(name+" ");

for(Integer key : player) {

String value = pooker.get(key);

System.out.print(value+" ");

}

System.out.println();

}

}

包身工 大王 ♣2 ♥2 ♦2 ♦A ♦K ♣J ♥10 ♠9 ♣9 ♥9 ♦9 ♣5 ♦5 ♦4 ♠3 ♦3

清洁工 小王 ♠K ♥K ♠Q ♣Q ♦Q ♦J ♠10 ♦10 ♥8 ♠7 ♥7 ♦7 ♥5 ♠4 ♣3 ♥3

洗碗工 ♠2 ♥A ♣K ♥Q ♠J ♥J ♣10 ♠8 ♦8 ♣7 ♠6 ♣6 ♥6 ♦6 ♠5 ♣4 ♥4

底牌 ♠A ♣A ♣8

到此这篇关于Java实现斗地主最简代码实例的文章就介绍到这了,更多相关Java实现简单的斗地主案例内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

服务器斗地主代码java_Java实现斗地主最简代码实例相关推荐

  1. 极简HTML渲染引擎,CodeMirror 代码渲染神器的极简入门实例

    效果: image.png HTML: 保存 运行 JS 代码示例: // 渲染代码: var editor = CodeMirror.fromTextArea(document.getElement ...

  2. 组合的示例代码 java_java实现Composite组合模式的实例代码

    //20210121 写在前面:刚期末考试完,考了面向对象,里边儿有23个设计模式,我寻思着考完挨个儿实现一下,本文实现组合模式 组合模式核心思想类似文件夹的概念,构件树形结构,树形有叶子结点和文件夹 ...

  3. 用python写一个有AI的斗地主游戏(二)——简述后端代码和思路

    源码请看我的Github页面. 这是我一个课程的学术项目,请不要抄袭,引用时请注明出处. 本专栏系列旨在帮助小白从零开始开发一个项目,同时分享自己写代码时的感想. 请大佬们为我的拙见留情,有不规范之处 ...

  4. 斗地主java_java网络斗地主

    [实例简介] 该项目是java开发了一个网络流行的网络斗地主实例,对学习java网络编程非常有帮助 [实例截图] [核心代码] 网络斗地主 └── 网络斗地主 ├── bin │   ├── cont ...

  5. 30个Python常用极简代码,拿走就用

    点击上方"视学算法",选择加"星标"或"置顶" 重磅干货,第一时间送达 作者丨Fatos Morina 来源丨Python 技术 编辑丨极市 ...

  6. Rust 阴阳谜题,及纯基于代码的分析与化简

    Rust 阴阳谜题,及纯基于代码的分析与化简 雾雨魔法店专栏 https://zhuanlan.zhihu.com/marisa 来源 https://zhuanlan.zhihu.com/p/522 ...

  7. python1000个常用代码-30个Python常用极简代码,拿走就用

    学 Python 怎样才最快,当然是实战各种小项目,只有自己去想与写,才记得住规则.本文是 30 个极简任务,初学者可以尝试着自己实现:本文同样也是 30 段代码,Python 开发者也可以看看是不是 ...

  8. 零基础python必背代码-30个Python常用极简代码,拿走就用

    学 Python 怎样才最快,当然是实战各种小项目,只有自己去想与写,才记得住规则.本文是 30 个极简任务,初学者可以尝试着自己实现:本文同样也是 30 段代码,Python 开发者也可以看看是不是 ...

  9. Ubuntu16.04 搭建SVN服务器(建立版本仓及import和checkout代码)

    Ubuntu16.04 搭建SVN服务器(建立版本仓及import和checkout代码) 1.    安装subversion sudo apt-get install subversion 2.  ...

最新文章

  1. JavaScript学习记录 (三) 函数和对象
  2. 稀疏模型与结构性稀疏模型
  3. JS实现上下左右四方向无间隙滚动
  4. 财富信息不需要传userID后台会根据保存的session提供数据
  5. android集成genymotion
  6. jQuery最核心的基础设施之一——数据缓存模块进化史
  7. 服务器如何关闭登录日志文件,linux云服务器登录日志文件
  8. 小议jQuery插件开发
  9. 汝跟被升职者之间,不存在竞争关系
  10. 油猴脚本 | 油猴脚本下载 | 油猴脚本大全
  11. 【信号处理】基于Matlab实现男女音变声系统
  12. 华北电力大学控制与计算机工程学院怎么样,华北电力大学控制与计算机工程学院实践部10月25日动保劳动感想...
  13. PayPal开发文档整理(8)——PayPal支付产品和解决方案
  14. 阅读源码-理解torch.utils.data、torch.utils.data.Dataset、torch.utils.data.DataLoader的工作方式
  15. [WIN7]怎样设置切换输入法变成CTRL+SHIFT
  16. Mac干货 如何快速的在Mac上安装Windows双系统?虚拟机Parallels Desktop +Bootcamp安装
  17. 用C语言学生成绩数据库排序功能设计,[c语言学生成绩管理系统]C语言学生成绩管理系统实验报告...
  18. web使用字体包_如何使用跨浏览器Web字体,第2部分
  19. 预防艾滋病知识宣传栏
  20. h5网页在微信客户端打开,上传图片不能调用相机

热门文章

  1. 【创建型】建造者模式(Builder Pattern)
  2. php旋转图片,php旋转图片90度的实例分享
  3. Linux系统安装IDEA保姆级教程
  4. 零基础小白要知道的次世代游戏建模这10问,不然如何轻松征服游戏公司主美?
  5. 职称考试计算机基础知识,中级职称计算机考试题「附答案」
  6. EI会议:移动互联网、云计算和信息安全国际学术会议(MICCIS 2023)
  7. 算法简介:二分图最大匹配
  8. Python opencv进行矩形识别
  9. Mac更改账户和个人文件夹名称
  10. 【ACMMM 2022】Depth-inspired Label Mining for Unsupervised RGB-D Salient Object Detection