【Java】Java基础 使用集合实现斗地主分牌

427ef4152dbf4b6c92618a198935cb6c.png

  📝个人主页:哈__

期待您的关注 

1b7335aca73b41609b7f05d1d366f476.gif

今天使用集合TreeSet来实现一个斗地主的分牌流程。

TreeSet集合的一个特点就是 元素有序,这样就方便我们分的牌自动排序。

0.思路

1.创建玩家手牌集合

我们到时候分的牌都存储在这里,但你可能会有疑问,因为存储的泛型是Integer,但扑克牌是有花色的,这该如何实现?

         TreeSet<Integer> zhangsan=new TreeSet<Integer>();TreeSet<Integer> lisi=new TreeSet<Integer>();TreeSet<Integer> wangwu=new TreeSet<Integer>();TreeSet<Integer> dipai=new TreeSet<Integer>();

2.创建牌堆 

我们创建了一个名为poke的HashMap结构,poke用来存储我们的扑克,而poke的key是每一张牌的一个id,value就是具体的牌。

        HashMap<Integer,String>poke=new HashMap<Integer,String>();String[] color={"♦","♣","♥","♠"};String[] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};

我们到时候洗牌的时候,洗的是这些id,但是并不是直接在poke中洗,poke的作用只是记录我们有哪些牌。所以 我们在创建一个用来洗牌的数组,并把所有的id放入。

        ArrayList<Integer> xipai=new ArrayList<Integer>();

3. 把牌放入牌堆

遍历我们的String数组,把花色和牌号组合一下并放入poke中,同时把poke中的key放入我们的洗牌集合中。最后不要忘了大小王。

        int index=0;for(String Number:number){for(String Color:color){String POKE=Color+Number;poke.put(index,POKE);xipai.add(index);index+=1;}}poke.put(52,"小王");poke.put(53,"大王");xipai.add(52);xipai.add(53);

4.洗牌 

一行代码即可,使用Collecitons自带的数组打乱方法。

    Collections.shuffle(xipai);

5.进行分牌 

如果只剩下最后三张了,就直接放入到我们的底牌集合当中,否则的话就进行模3取余操作进行判断应该分给谁。

        for(int i=0;i<xipai.size();i++){if(i>=xipai.size()-3){dipai.add(xipai.get(i));}else{if(i%3==0){zhangsan.add(xipai.get(i));}else if(i%3==1){lisi.add(xipai.get(i));}elsewangwu.add(xipai.get(i));}}

6.完整代码 

public class Poker {public static void main(String[] args) {HashMap<Integer,String>poke=new HashMap<Integer,String>();String[] color={"♦","♣","♥","♠"};String[] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};ArrayList<Integer> xipai=new ArrayList<Integer>();TreeSet<Integer> zhangsan=new TreeSet<Integer>();TreeSet<Integer> lisi=new TreeSet<Integer>();TreeSet<Integer> wangwu=new TreeSet<Integer>();TreeSet<Integer> dipai=new TreeSet<Integer>();int index=0;for(String Number:number){for(String Color:color){String POKE=Color+Number;poke.put(index,POKE);xipai.add(index);index+=1;}}poke.put(52,"小王");poke.put(53,"大王");xipai.add(52);xipai.add(53);Collections.shuffle(xipai);//进行发牌for(int i=0;i<xipai.size();i++){if(i>=xipai.size()-3){dipai.add(xipai.get(i));}else{if(i%3==0){zhangsan.add(xipai.get(i));}else if(i%3==1){lisi.add(xipai.get(i));}elsewangwu.add(xipai.get(i));}}//进行看牌,用方法实现LookPoker("张三",gyh,poke);LookPoker("李四",zch,poke);LookPoker("王五",wjq,poke);LookPoker("底牌",dipai,poke);//System.out.println(poke);}public static void LookPoker(String name,TreeSet<Integer>set,HashMap<Integer,String>map){System.out.print(name+"的牌是:");for(Integer i:set){String poke=map.get(i);System.out.print(poke+" ");}System.out.println();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/641663.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Web前端安全问题分类综合以及XSS、CSRF、SQL注入、DoS/DDoS攻击、会话劫持、点击劫持等详解,增强生产安全意识

前端安全问题是指发生在浏览器、单页面应用、Web页面等前端环境中的各类安全隐患。Web前端作为与用户直接交互的界面&#xff0c;其安全性问题直接关系到用户体验和数据安全。近年来&#xff0c;随着前端技术的快速发展&#xff0c;Web前端安全问题也日益凸显。因此&#xff0c…

山海鲸电力看板:运维数据一目了然

在信息化高速发展的今天&#xff0c;电力行业的运维管理也迎来了前所未有的变革。山海鲸可视化智慧电力运维可视化看板&#xff0c;以其独特的数据整合能力和直观的可视化效果&#xff0c;成为了电力行业运维管理的得力助手&#xff0c;为电力的稳定运行提供了强大的技术支撑。…

[图解]软件开发中的糊涂用语-05-非功能需求算不算糊涂用语

0 00:00:00,350 --> 00:00:02,997 今天呢&#xff0c;我们来看一个用语 1 00:00:02,997 --> 00:00:04,100 非功能需求 2 00:00:04,620 --> 00:00:07,060 这个算不算糊涂用语 3 00:00:09,890 --> 00:00:13,000 这是来自一个学员的问题 4 00:00:13,000 --> 00…

详解Mixtral-8x7B背后的MoE!

高端的模型往往只需最朴素的发布方式。 这个来自欧洲的大模型团队在12月8日以一条磁力链接的方式发布了Mixtral-8x7B,这是一种具有开放权重的**「高质量稀疏专家混合模型」**(SMoE)。 该模型在大多数基准测试中都优于Llama2-70B,相比之下推理速度快了6倍,同时在大多数标准基…

内存泄漏详解

一、什么是内存泄漏&#xff1f;二、内存泄漏的原因三、内存泄漏的影响四、如何检测和解决内存泄漏&#xff1f;五、总结 一、什么是内存泄漏&#xff1f; 内存泄漏指的是程序中已分配的内存没有被正确释放&#xff0c;导致这部分内存无法被再次利用&#xff0c;最终导致内存资…

OLED透明屏的制造过程是怎样的?

OLED透明屏的制造过程是一个复杂且精细的工艺&#xff0c;它涉及多个关键步骤以确保最终的显示效果和透明度。以下是OLED透明屏制造过程的主要步骤&#xff1a; 基板准备&#xff1a;制造过程始于对基板的准备。基板通常是玻璃或塑料材料&#xff0c;需要进行清洗和表面处理&am…

echerts饼图分割操作

在饼图制作中遇到了一个难点就是饼图中间是分散的 试了很多方法&#xff0c;最后选择了给每个值中间再加一节的处理方式&#xff0c;并把颜色设置为透明就能达到相同效果。 处理后的样式&#xff1a; 代码&#xff1a; let list this.data.list;/饼图内部展示数据// let _t…

金融风控信用评分卡建模(Kaggle give me credit数据集)

1 数据预处理数据 数据来源于Kaggle的Give Me Some Credit&#xff0c;包括25万条个人财务情况的样本数据 1.1 导包读数据 import pandas as pd import numpy as np import matplotlib.pyplot as plt from sklearn.ensemble import RandomForestRegressor import seaborn as …

Midjourney与waifu2x双剑合璧:完美打造超高清动漫图像

在追求完美的动漫图像时&#xff0c;质量和分辨率是两个关键因素。Midjourney&#xff08;一个神秘而强大的AI图像生成工具&#xff09;与waifu2x&#xff08;一个专门用于放大动漫风格图像的AI工具&#xff09;的结合使得创造超高清的动漫图像变得触手可及。本文将引导您如何使…

geoserver安装部署

1.配置Java环境 首先我们先来官网下载JDK&#xff0c;由于我们的geoserver版本是和 java11 和 java17 适配的&#xff0c;所以我们选择 java11 下载好了点击安装&#xff0c;无脑下一步就行&#xff0c;想改路径就改一下&#xff0c;不过需要把路径记住 &#xff0c;后面需要用…

【代码随想录刷题记录】LeetCode367有效的完全平方数

题目地址 1. 思路 这个题就用二分查找的思想&#xff0c;比LeetCode69x的平方根要简单一些&#xff0c;那个还要处理开平方不是整数的情况&#xff0c;这个直接就按左闭右闭&#xff0c;middle的平方是num就返回true&#xff0c;否则继续迭代二分直到找到middle的平方是num的…

docker 报错 error adding seccomp filter rule for syscall clone3

网上有一些说法&#xff0c;例如重新安装docker 但是我自己尝试&#xff0c;用 –security-opt seccompunconfined 就可以&#xff0c;但是需要把这个命令放到紧挨着run的位置&#xff0c;如果放到偏后的位置&#xff0c;可能不起作用。 以下命令是其他网友启动是的命令&…