文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用JavaSE来模拟斗地主

2023-06-14 10:44

关注

本篇内容主要讲解“如何使用JavaSE来模拟斗地主”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用JavaSE来模拟斗地主”吧!

Java可以用来干什么

Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4. 网页开发;5. 企业级应用开发;6. Java大数据开发;7.游戏开发等。

通过模拟斗地主案例来练习集合的使用

结果预览:

每次发牌后,三位玩家的手牌是随机的并且已经按照手牌大小排完序,运行两次验证手牌的随机性。

如何使用JavaSE来模拟斗地主

如何使用JavaSE来模拟斗地主

马老师的牌还不错,芜湖~起飞

思路:

创建HashMap,键是编号,值是牌。
2.创建ArrayList,存储编号。
3.创建花色数组和点数数组。
4.从0开始往HashMap里面存储编号,并存储对应的牌。同时往ArrayList里面存储编号。
5.洗牌(洗的是编号),用Collections的shuffl()方法实现。
6.发牌(发的也是编号,为了保证编号是排序的,创建TreeSet集合。
7.定义方法看牌(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)
8.调用看牌方法

为了方便理解,我用图形的方式来描述下过程:

如何使用JavaSE来模拟斗地主

具体代码实现:

1.创建集合装扑克牌

 //创建HashMap集合   key是编号用Integer  value是牌用String            HashMap<Integer,String>  hm=new HashMap<>();            //创建ArrayList集合用来存储编号            ArrayList<Integer> list=new ArrayList<>();            //创建花色数组和点数数组            String [] color={"♠", "♦", "♥","♣"};            String [] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};            //从0开始往HashMap集合里面存储编号,并存储对应的牌。同时往ArrayList集合里面存储编号            int index=0;            //增强For循环存储花色和点数            for(String num:number){                for(String col:color){                    hm.put(index,col+num);                    list.add(index);                    index++;                }            }           //52张牌存完了 还剩大小王  现在添加进去            hm.put(index,"小王");            list.add(index);            index++;            hm.put(index,"大王");            list.add(index);            //以上的操作实现了把54张扑克牌放入一个集合容器。

2.洗牌和发牌

   //洗牌(洗的是编号),用collections的shuffle()方法实现。            Collections.shuffle(list);            //发牌  用TreeSet接收  用三位玩家名字命名            TreeSet<Integer> PDD=new TreeSet<>();            TreeSet<Integer> DaSiMa=new TreeSet<>();            TreeSet<Integer> LuBenWei=new TreeSet<>();            //三张底牌            TreeSet<Integer> finalCard=new TreeSet<>();            for(int x=0;x<list.size();x++){                //定义一个变量接收索引                int  a= list.get(x);                //最后三个索引                if(x>=list.size()-3){              finalCard.add(a);                }else if(x%3 == 0){                    PDD.add(a);                }else if(x%3 == 1){                    DaSiMa.add(a);                }else {                    LuBenWei.add(a);                }            }

3.定义看牌方法

  //定义看牌的方法(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)        public  static void lookPoker(String name,TreeSet<Integer> ts,HashMap<Integer,String>  hm ){            System.out.print(name+"的手牌为:");            //遍历牌 就是遍历索引            for(Integer key:ts){                String poker = hm.get(key);                System.out.print(poker+" ");            }            System.out.println();        }

原码:

package 模拟斗地主;    import java.util.ArrayList;    import java.util.Collections;    import java.util.HashMap;    import java.util.TreeSet;        public class ChinesePoker {        public static void main(String[] args) {            //创建HashMap集合   key是编号用Integer  value是牌用String            HashMap<Integer,String>  hm=new HashMap<>();            //创建ArrayList集合用来存储编号            ArrayList<Integer> list=new ArrayList<>();            //创建花色数组和点数数组            String [] color={"♠", "♦", "♥","♣"};            String [] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};            //从0开始往HashMap集合里面存储编号,并存储对应的牌。同时往ArrayList集合里面存储编号            int index=0;            //增强For循环存储花色和点数            for(String num:number){                for(String col:color){                    hm.put(index,col+num);                    list.add(index);                    index++;                }            }           //52张牌存完了 还剩大小王  现在添加进去            hm.put(index,"小王");            list.add(index);            index++;            hm.put(index,"大王");            list.add(index);            //洗牌(洗的是编号),用collections的shuffle()方法实现。            Collections.shuffle(list);            //发牌  用TreeSet接收  用三位玩家名字命名            TreeSet<Integer> PDD=new TreeSet<>();            TreeSet<Integer> DaSiMa=new TreeSet<>();            TreeSet<Integer> LuBenWei=new TreeSet<>();            //三张底牌            TreeSet<Integer> finalCard=new TreeSet<>();            for(int x=0;x<list.size();x++){                //定义一个变量接收索引                int  a= list.get(x);                //最后三个索引                if(x>=list.size()-3){              finalCard.add(a);                }else if(x%3 == 0){                    PDD.add(a);                }else if(x%3 == 1){                    DaSiMa.add(a);                }else {                    LuBenWei.add(a);                }            }            //调用看牌方法            lookPoker("PDD",PDD,hm);            lookPoker("大司马",DaSiMa,hm);            lookPoker("卢本伟",LuBenWei,hm);            lookPoker("底牌",finalCard,hm);        }            //定义看牌的方法(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)        public  static void lookPoker(String name,TreeSet<Integer> ts,HashMap<Integer,String>  hm ){            System.out.print(name+"的手牌为:");            //遍历牌 就是遍历索引            for(Integer key:ts){                String poker = hm.get(key);                System.out.print(poker+" ");            }            System.out.println();        }    }

到此,相信大家对“如何使用JavaSE来模拟斗地主”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯