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

这篇具有很好参考价值的文章主要介绍了【Java】Java基础 使用集合实现斗地主分牌。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【Java】Java基础 使用集合实现斗地主分牌,java,开发语言

  📝个人主页:哈__

期待您的关注 

【Java】Java基础 使用集合实现斗地主分牌,java,开发语言

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

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

0.思路

【Java】Java基础 使用集合实现斗地主分牌,java,开发语言

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取余操作进行判断应该分给谁。文章来源地址https://www.toymoban.com/news/detail-860019.html

        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));
                }else
                    wangwu.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));
                }else
                    wangwu.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();
    }
}

到了这里,关于【Java】Java基础 使用集合实现斗地主分牌的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【华为OD机试 2023 B卷 | 100分】斗地主之顺子(C++ Java JavaScript Python)

    华为OD统一考试A卷+B卷 新题库说明 2023年5月份,华为官方已经将的 2022/0223Q(1/2/3/4)统一修改为OD统一考试(A卷)和OD统一考试(B卷)。 你收到的链接上面会标注A卷还是B卷。请注意:根据反馈,目前大部分收到的都是B卷。但是仍有概率抽到A卷。 A卷对应2023的新题库(2022Q4 2

    2024年02月08日
    浏览(43)
  • 逆向破解学习-单机斗地主

    9000 是成功的代码 ` import de.robv.android.xposed.XC_MethodHook; import de.robv.android.xposed.XposedHelpers; import de.robv.android.xposed.callbacks.XC_LoadPackage; public class HookComJuneGameDouDiZhu extends HookImpl{ @Override public String packageName() { return “com.june.game.doudizhu”; } } `

    2024年02月13日
    浏览(51)
  • 【华为OD机试真题】1220 - 斗地主之顺子(JAVA C++ Python JS) | 机试题+算法思路+考点+代码分析

    🍂个人博客首页: KJ.JK   🍂专栏介绍: 华为OD机试真题汇总,定期更新华为OD各个时间阶段的机试真题,每日定时更新,本专栏将使用Python语言进行更新解答,包含真题,思路分析,代码参考,欢迎大家订阅学习

    2024年02月06日
    浏览(55)
  • 微信小程序斗地主完整代码及步骤

    一、准备工作 1. 安装微信开发者工具,并登录微信小程序账号; 2. 准备斗地主游戏的图片资源; 3. 准备斗地主游戏的音效资源; 二、创建小程序 1. 打开微信开发者工具,点击“新建小程序”,输入小程序名称,选择小程序的项目目录,点击“创建”; 2. 在小程序的项目目

    2024年02月04日
    浏览(319)
  • AI 全自动玩斗地主,靠谱吗?Douzero算法教程

    你觉得,AI 全自动玩斗地主,胜率能有多高? 真就有100%胜率,实现欢乐豆自由? 我让这个 AI 自己玩了一小时,结果出乎意料。 先不着急说最终结果,我们先来看看这个 AI 有多强。 Ai斗地主,就是通过 AI 算法分析游戏画面,获取玩家角色、手牌等信息。 完全自主决策这把

    2024年02月08日
    浏览(44)
  • 用python写一个有AI的斗地主游戏(一)——开始前的准备

    源码请看我的Github页面。 这是我一个课程的学术项目,请不要抄袭,引用时请注明出处。 本专栏系列旨在帮助小白从零开始开发一个项目,同时分享自己写代码时的感想。 请大佬们为我的拙见留情,有不规范之处烦请多多包涵! 不知道有多少喜欢计算机相关学科的人,一开

    2024年02月07日
    浏览(36)
  • HTML小游戏19 —— html5版开心斗地主小游戏(附完整源码)

    💂 网站推荐:【神级源码资源网】【摸鱼小游戏】 🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】 💅 想寻找共同学习交流、摸鱼划水的小伙伴,请点击【摸鱼学习交流群】 本节教程我会带大家使用 HTML 、CSS和 JS 来制作一个 html5版开心斗地主小游戏 🕹️ 本文

    2024年02月03日
    浏览(87)
  • Java基础——Set集合实现类

    (1)Set集合实现类特点: HashSet:无序,不重复,无索引。 LinkedHashSet:有序,不重复,无索引。 TreeSet:排序,不重复,无索引。  (2)HashSet集合 1.底层原理: HashSet集合底层采取哈希表存储的数据。 哈希表是一种对于增删改查数据性能都较好的结构。 2.哈希表的组成: 

    2023年04月13日
    浏览(42)
  • Java基础——LinkedList集合实现栈和队列

    (1)LinkedList的特点: 底层数据结构是双链表,查询慢,首尾操作的速度是极快的,所以多了很多首位操作的特有API。 (2)LinkedList集合的特有功能: 方法名称 说明 public void addFirst(E e) 在该列表开头插入指定的元素 public void addLast(E e) 将指定的元素追加到此列表的末尾 publ

    2023年04月12日
    浏览(45)
  • 【Java基础】Java8 使用 stream().filter()过滤List对象(查找符合条件的对象集合)

    本篇主要说明在Java8及以上版本中,使用stream().filter()来过滤List对象,查找符合条件的集合。 集合对象以学生类(Student)为例,有学生的基本信息,包括:姓名,性别,年龄,身高,生日几项。 我的学生类代码如下: 下面来添加一些测试用的数据,代码如下: 添加过滤条件

    2024年02月12日
    浏览(68)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包