斗地主案例思路分析及代码实现

简介: 斗地主案例需求分析及代码实现 /* 斗地主综合案例: 1.准备牌 2.洗牌 3.发牌 4.看牌 */ import java.util.ArrayList; import java.util.Collections; public class DouDiZhu { public static voi

斗地主案例需求分析及代码实现


微信图片_20220426125256.png


/*
斗地主综合案例:
    1.准备牌
    2.洗牌
    3.发牌
    4.看牌
 */
import java.util.ArrayList;
import java.util.Collections;
public class DouDiZhu {
    public static void main(String[] args) {
        //1.准备牌
        //定义一个存储54张牌的ArrayList集合,泛型使用String
        ArrayList<String> poker = new ArrayList<>();
        //定义两个数组,一个数组存储拍的花色,一个数组存储牌的序号
        String[] colors = {"♠","♥","♣","♦"};
        String[] numbers = {"2","A","K","Q","J","10","9","8","7","6","5","4","3"};
        //先把大王和小王存储到poker集合中
        poker.add("大王");
        poker.add("小王");
        //循环嵌套遍历两个数组,组装52张牌
        for (String color : colors) {
            for (String number : numbers) {
                //把组装好的牌存储到poker集合中
                poker.add(color+number);
            }
        }
        //System.out.println(poker);
        /*
        2.洗牌
        使用集合的工具类Collections中的方法
        static void shuffle(List<?> list) 使用默认的随机源随机排列指定的列表。
         */
        Collections.shuffle(poker);
        //System.out.println(poker);
        /*
        3.发牌
         */
        //定义4个集合,存储玩家的牌和底牌
        ArrayList<String> player01 = new ArrayList<>();
        ArrayList<String> player02 = new ArrayList<>();
        ArrayList<String> player03 = new ArrayList<>();
        ArrayList<String> diPai = new ArrayList<>();
        /*
        遍历poker集合,获取每一张牌
        使用poker结合的索引%3给三个玩家轮流发牌
        剩余三张牌给底牌
        注意:
            先判断底牌(i>=51),否则牌就发没了
         */
        for (int i = 0; i < poker.size(); i++) {
            //获取每一张牌
            String p = poker.get(i);
            //轮流发牌
            if (i>=51){
                //给底牌发牌
                diPai.add(p);
            }else if (i%3==0){
                //给玩家1发牌
                player01.add(p);
            }else if (i%3==1){
                //给玩家2发牌
                player02.add(p);
            }else if (i%3==2){
                //给玩家3发牌
                player03.add(p);
            }
        }
        //4.看牌
        System.out.println("刘德华:"+player01);
        System.out.println("周润发:"+player02);
        System.out.println("周星驰:"+player03);
        System.out.println("底牌:"+diPai);
    }
}


相关文章
|
算法
贪心算法入门典型案例
在N行M列的正整数矩阵中,要求从每行中选出1个数,使得选出的总共N个数的和最大。输入:第一行两个正整数N和M,用空格隔开,表示行数和列数 第2行到第N+1行,每行M个用空格隔开的整数 ,表示矩阵 输出最大总和 1 #include 2 #include 3 #include 4 5 ...
1049 0
|
4月前
|
算法
写题思路的分享
写题思路的分享
28 0
|
9月前
|
机器学习/深度学习 存储 缓存
力扣70爬楼梯:思路分析+优化思路+代码实现+补充思考
力扣70爬楼梯:思路分析+优化思路+代码实现+补充思考
74 0
|
9月前
力扣面试题 08.06. 汉诺塔问题:思路分析+图文详解+代码实现
力扣面试题 08.06. 汉诺塔问题:思路分析+图文详解+代码实现
101 0
|
10月前
|
机器学习/深度学习 算法 Java
Java实现递归及经典案例(不死神兔三种方式)
本文简单介绍了递归的概念和使用递归时的注意事项,并分享了求阶乘案例(两种方式)、不死神兔案例(三种方式)以及利用递归删除一个带内容的文件的案例;
128 0
|
存储 算法 C++
数据结构与算法——第四节 栈和队列(C 模拟实现+思路分析+运行截图)
对于栈和队列,我们在这里只是把 其底层的原理简单的说一下,等到C++说到STL的时候,我们还会详细地说。
149 0
数据结构与算法——第四节 栈和队列(C 模拟实现+思路分析+运行截图)
|
物联网 开发者 智能硬件
[视频]理思路|学习笔记(一)
快速学习[视频]理思路
72 0
|
物联网 数据库 知识图谱
[视频]理思路|学习笔记(二)
快速学习[视频]理思路|学习笔记
56 0
|
算法 Java 编译器
如何用JAVA实现迷宫回溯问题
如何用JAVA实现迷宫回溯问题
95 1
如何用JAVA实现迷宫回溯问题
|
算法 搜索推荐 C++
【算法】面试必备之0基础学算法 快速排序(详细讲解+私人笔记+代码展示)
二分查找又称折半查找、二分搜索、折半搜索等,是在分治算法基础上设计出来的查找算法,对应的时间复杂度为O(logn)。到这里是不是感觉很熟悉,我们前两期的算法知识,也是基于分治的方法去进行学习的,如果有这方面还不了解的朋友,你可以到我的第一篇文章(0基础学算法)里面去查看一下。
113 0
【算法】面试必备之0基础学算法 快速排序(详细讲解+私人笔记+代码展示)