编程语言
首页 > 编程语言> > JAVA基础 实现斗地主发牌 用到三种集合的特性 “Arraylist”,“TreeSet”, “Hashmap“

JAVA基础 实现斗地主发牌 用到三种集合的特性 “Arraylist”,“TreeSet”, “Hashmap“

作者:互联网

流程:

1.创建Hashmap集合 模拟牌盒 键是牌的id  值是牌面 

2.创建ArrayList集合  元素对应牌的id   1~53

3.创建两个数组 数组1 存储四个花色  数组2 存储0~51+大,小王

4.Collections.shuffle 打乱Arraylist集合  模拟洗牌

5.遍历Arraylist集合  模拟发牌

6.创建TreeSet集合  使牌对应的id排序  模拟理牌

7.遍历TreeSet集合 根据元素对应Hashmap的键 找到对应的值 模拟看牌

import java.util.*;

public class DDZdome {
    public static void main(String[] args) {
        HashMap<Integer, String> hash = new HashMap<Integer, String>();

        ArrayList<Integer> arr = new ArrayList<Integer>();

        String[] huase = {"♠", "♥", "♣", "♦" };
        String[] pai = {"3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "k", "A", "2" };
        int id = 0;
        for (String p : pai) {
            for (String h : huase) {
                hash.put(id, h + p);
                arr.add(id);
                id++;
            }
        }
        hash.put(id, "小王");
        arr.add(id);
        id++;
        hash.put(id, "大王");
        arr.add(id);
        System.out.println(hash);

        Collections.shuffle(arr);

        TreeSet<Integer> pl1 = new TreeSet<Integer>();
        TreeSet<Integer> pl2 = new TreeSet<Integer>();
        TreeSet<Integer> pl3 = new TreeSet<Integer>();
        TreeSet<Integer> dp = new TreeSet<Integer>();


        for (int i=0;i<arr.size();i++){
            if (i>=arr.size()-3){
                dp.add(arr.get(i));
            }else if(i%3==0){
                pl1.add(arr.get(i));
            }else if(i%3==1){
                pl2.add(arr.get(i));
            }else if(i%3==2){
                pl3.add(arr.get(i));
            }
        }

        System.out.println(pl1);
        show("地主",pl1,hash);
        show("农民",pl2,hash);
        show("农民",pl3,hash);
        show("底牌",dp,hash);
    }

    public static void show(String name,TreeSet<Integer> tree,HashMap<Integer, String> hash){
        System.out.print(name+" :");
        for (int i:tree){
            System.out.print(hash.get(i)+" ");
        }
        System.out.println();
    }
    
}

输出结果:

{0=♠3, 1=♥3, 2=♣3, 3=♦3, 4=♠4, 5=♥4, 6=♣4, 7=♦4, 8=♠5, 9=♥5, 10=♣5, 11=♦5, 12=♠6, 13=♥6, 14=♣6, 15=♦6, 16=♠7, 17=♥7, 18=♣7, 19=♦7, 20=♠8, 21=♥8, 22=♣8, 23=♦8, 24=♠9, 25=♥9, 26=♣9, 27=♦9, 28=♠10, 29=♥10, 30=♣10, 31=♦10, 32=♠J, 33=♥J, 34=♣J, 35=♦J, 36=♠Q, 37=♥Q, 38=♣Q, 39=♦Q, 40=♠k, 41=♥k, 42=♣k, 43=♦k, 44=♠A, 45=♥A, 46=♣A, 47=♦A, 48=♠2, 49=♥2, 50=♣2, 51=♦2, 52=小王, 53=大王}
[0, 2, 3, 5, 6, 7, 10, 14, 16, 18, 26, 32, 38, 42, 44, 45, 48]
地主 :♠3 ♣3 ♦3 ♥4 ♣4 ♦4 ♣5 ♣6 ♠7 ♣7 ♣9 ♠J ♣Q ♣k ♠A ♥A ♠2 
农民 :♥5 ♦5 ♥6 ♦6 ♥7 ♦7 ♣8 ♦8 ♥9 ♠10 ♦10 ♥J ♦J ♥Q ♥k ♦A 小王 
农民 :♥3 ♠4 ♠5 ♠6 ♠8 ♥8 ♦9 ♣10 ♣J ♠Q ♦Q ♦k ♣A ♥2 ♣2 ♦2 大王 
底牌 :♠9 ♥10 ♠k 

 

标签:10,arr,hash,斗地主,发牌,add,JAVA,id,TreeSet
来源: https://blog.csdn.net/JAVAlife2021/article/details/117218844