Loading

Java集合综合练习




学完了集合后我们可以开始做一个简易版的 “斗地主 ” 了,但是呢咱们这个斗地主只能实现制造牌,洗牌、发牌、看牌这几个简单的功能,并不是我们玩的 ” 真人版斗地主 “ 哈!


链接:

Collections、Set、Map介绍


代码如下:


public static void main(String[] args) {
        //创建一个Map集合,键表示标记为Integer类型,值表示牌为String类型
        HashMap<Integer, String> hashMap = new HashMap<>();

        //创建四个花色的集合
        ArrayList<String> Suit = new ArrayList<>();
        Collections.addAll(Suit, "♥", "♠", "♣", "♦");

        //创建用来存储13张牌面值的单列集合,牌面值需要按扑克牌的大小顺序依次存储,方便后面标记
        ArrayList<String> brandValue = new ArrayList<>();
        Collections.addAll(brandValue, "2", "A", "K", "Q", "J", "10", "9", "8", "7", "6", "5", "4", "3");

        //定义一个标记初始化为1,为后面的发牌后牌面值排序
        int flag = 1;

        /*大小王最大所以需要提前放进去并且放在最前面,以标记作为键,大小王作为值,依次添加到Map集合中
        确保之后的排序正常,添加完了之后,标记需要+1*/
        hashMap.put(flag++, "大王");
        hashMap.put(flag++, "小王");

        //将牌面值和花色进行组合,外层循环执行一次内层循环执行所有,牌面值集合作为外层循环,花色集合作为内层循环
        for (String i : brandValue) {
            for (String j : Suit) {
                //拼接4种花色和13张牌面值组成剩余的52张牌
                String card = j + i;
                /*将标记作为键,拼接好的牌作为值放到集合中,每添加一张牌标记就+1
                依次添加,这样最大的牌就会对应最小的标记值*/
                hashMap.put(flag++, card);
            }
        }
        System.out.println("----------------------造牌----------------------");
        //打印所有拼接好的牌面值(含标记)
        System.out.println("所有的牌面值:" + hashMap.values());

        System.out.println("----------------------洗牌----------------------");
        /*将map集合转换成List集合,获取map集合中所有的键(标记)并存放到keyList集合中
        (List集合再调用shuffle()方法打乱牌的顺序,存的是乱序的标记)*/

        /*Set<Integer> key = hashMap.keySet();
        ArrayList<Integer> keyList = new ArrayList<>(key);*/
        ArrayList<Integer> keyList = new ArrayList<>(hashMap.keySet());
        //打乱所有的键(标记),模拟洗牌
        Collections.shuffle(keyList);

        //打印打乱顺序后的所有牌(标记),实际上就是List集合中乱序后的所有标记
        System.out.println("打乱后的标记:" + keyList);

        /*创建4个TreeMap集合,分别用来存储三张底牌以及玩家1,玩家2,玩家3的牌(标记),
        TreeMap集合会自动对所有元素进行升序排列,所以发完牌后玩家的手牌会按标记从大
        到小展示出来*/
        TreeMap<Integer,String> play1 = new TreeMap<>();
        TreeMap<Integer,String> play2 = new TreeMap<>();
        TreeMap<Integer,String> play3 = new TreeMap<>();
        TreeMap<Integer,String> threeCard = new TreeMap<>();

        for (int i = 0; i < keyList.size(); i++) {
            //在List集合中找到打乱顺序后的标记
            Integer cardFlag = keyList.get(i);
            //根据标记在hashMap集合中找到对应的牌
            String getCard = hashMap.get(cardFlag);
            //根据规则先发底牌然后依次发牌给每个玩家,模拟发牌
            if(i >= 51){
                //如果标记的索引>=51,该标记给底牌
                threeCard.put(cardFlag,getCard);
            }else if(i % 3 == 0){
                //如果标记的索引%3==0,该标记给玩家1
                play1.put(cardFlag,getCard);
            }else if(i % 3 == 1){
                //如果标记的索引%3==1,该标记给玩家2
                play2.put(cardFlag,getCard);
            }else{
                //如果标记的索引%3==2,该标记给玩家3
                play3.put(cardFlag,getCard);
            }
        }

        System.out.println("----------------------看牌----------------------");
        //打印三个玩家的手牌以及三张底牌,模拟看牌
        System.out.println("底牌:" + threeCard.values());
        System.out.println("玩家一的牌:" + play1.values());
        System.out.println("玩家二的牌:" + play2.values());
        System.out.println("玩家三的牌:" + play3.values());
    }
    

以上基本都有注解标明所以就没做过多的介绍了相信这难不倒聪明的你们!

posted @ 2022-09-20 13:12  请叫我阿杰  阅读(77)  评论(0编辑  收藏  举报