使用JavaSE来模拟斗地主

 更新时间:2021年04月08日 15:23:29   作者:佳明Ryan  
这篇文章主要介绍了使用JavaSE来模拟斗地主,对棋牌游戏有研究的同学可以参考一下

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

结果预览:

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

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

思路:

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

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

具体代码实现:

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;
    /*需求:
        通过程序实现 斗地主过程中的洗牌,发牌和看牌功能,并且为了方便看牌手牌要排序。
        思路:
        1:创建HashMap集合,键是编号,值是牌。
        2:创建Arraylist集合用于存储编号。
        3:创建花色数组和点数数组。
        4:从0开始往HashMap集合里面存储编号,并存储对应的牌。同时往ArrayList集合里面存储编号。
        5 :洗牌(洗的是编号),用collections的shuffle()方法实现。
        6:发牌(发的也是编号,为了保证编号是排序的,创建TreeSet集合接收
        7:定义方法看牌(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)
        8:调用方法看牌
        */
    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来模拟斗地主的详细内容,更多关于JavaSE斗地主的资料请关注脚本之家其它相关文章!

相关文章

  • 浅谈Java的虚拟机结构以及虚拟机内存的优化

    浅谈Java的虚拟机结构以及虚拟机内存的优化

    这篇文章主要介绍了Java的虚拟机结构以及虚拟机内存的优化,讲到了JVM的堆和栈空间及GC垃圾回收等重要知识,需要的朋友可以参考下
    2016-03-03
  • Java Hibernate中的持久化类和实体类关系

    Java Hibernate中的持久化类和实体类关系

    Hibernate是一种Java对象关系映射框架,通过持久化类将Java对象映射到数据库表中。持久化类需要实现无参构造器、具有标识属性和使用注解或XML进行映射。Hibernate通过Session来管理对象的状态,包括临时状态、持久化状态和游离状态
    2023-04-04
  • Java 分析并解决内存泄漏的实例

    Java 分析并解决内存泄漏的实例

    这篇文章主要介绍了Java 分析并解决内存泄漏的实例,帮助大家更好的理解和学习Java,感兴趣的朋友可以了解下
    2020-08-08
  • Java实现文件分割和文件合并实例

    Java实现文件分割和文件合并实例

    本篇文章主要介绍了Java实现文件分割和文件合并实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • echarts图表导出excel示例

    echarts图表导出excel示例

    这篇文章主要介绍了echarts图表导出excel示例,需要的朋友可以参考下
    2014-04-04
  • SpringBoot基于AbstractRoutingDataSource实现多数据源动态切换

    SpringBoot基于AbstractRoutingDataSource实现多数据源动态切换

    本文主要介绍了SpringBoot基于AbstractRoutingDataSource实现多数据源动态切换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Java Exception 捕获和显示实例详解

    Java Exception 捕获和显示实例详解

    这篇文章主要介绍了Java Exception 捕获和显示实例详解的相关资料,需要的朋友可以参考下
    2017-03-03
  • SpringBoot集成JWT的工具类与拦截器实现方式

    SpringBoot集成JWT的工具类与拦截器实现方式

    这篇文章主要介绍了SpringBoot集成JWT的工具类与拦截器实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • Spring sentinel哨兵模式相关原理解析

    Spring sentinel哨兵模式相关原理解析

    这篇文章主要介绍了Spring sentinel哨兵模式相关原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Java使用GUI绘制线条的示例

    Java使用GUI绘制线条的示例

    这篇文章主要介绍了Java使用GUI绘制线条的示例,帮助大家更好的理解和学习java gui编程,感兴趣的朋友可以了解下
    2020-09-09

最新评论