JAVA实现扑克牌发牌及查看牌

今天学习集合的运用,老师给了一个有意思的题目,通过代码实现斗地主的发牌内容。现在将做法和代码展示给大家。

首先需要实现的功能:

  1. List集合存储 54个编号

  2. Map <key,value> key 对应的是编号 , value 是 牌的花色(红方梅黑)+ 具体的一张牌 ,比如 黑桃2

  3. 用2个数组 存放 花色+ 13张牌

  4. 将牌的信息 存入到 list和map

  5. 发牌了… (需要打乱顺序)

  6. 看一下 自己是什么牌 (看牌)

由于代码片上传有问题 就用截图来展示吧。
首先创建list集合和map集合,

public static void main(String[] args) {
    //存放编号
    List<Integer> list = new ArrayList<>();
    //保存牌信息
    Map<Integer, String> map = new HashMap<>();
    //4种花色
    String[] colors = {"♥", "♠", "♦", "♣"};
    //13张牌
    String[] numbers = {"A", "2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K"};

创建两个数组,分别存放 花色和牌数。
这里记录一下54张牌 存放到list

int index = 0;   //记录  54个牌 .从0-53
//存储 牌信息到上面2个集合
// 4*13 =52次
for (String num : numbers) {
    for (String col : colors) {
        map.put(index, col + num);
        list.add(index);
        index++;
    }
}

//处理大小王
map.put(52, "小王");
map.put(53, "大王");
list.add(52);
list.add(53);

接下来打乱牌的顺序,并且创建参与游戏的人(包括其中三张底牌)

//发牌之前先打乱顺序(洗牌)
Collections.shuffle(list);  //打乱0-53

//发牌准备人数和底牌 (3人 , 底牌3张)
List<Integer> p1 = new ArrayList<>();   //第1人
List<Integer> p2 = new ArrayList<>();   //第2人
List<Integer> p3 = new ArrayList<>();   //第3人
List<Integer> bottom = new ArrayList<>();   //底牌

接下来进行发牌,并将获得的牌进行排序

//发牌开始了
for (int i = 0; i < list.size(); i++) {
    //先弄出3张作为底牌
    if (i < 3) {
        bottom.add(list.get(i));
    }//剩余51了
    else if (i % 3 == 0) {
        p1.add(list.get(i));
    } else if (i % 3 == 1) {
        p2.add(list.get(i));
    } else {
        p3.add(list.get(i));
    }
}


//将自己的牌 排个序
Collections.sort(p1);
Collections.sort(p2);
Collections.sort(p3);
Collections.sort(bottom);

查看每个人获得的牌

    //看牌  (有3个人名 . 每个人都可以看自己的集合数据)
    // 需要3个数据 , 姓名+p1/p2/p3+map
    show("老王", p1, map);
    show("老张", p2, map);
    show("宋哲", p3, map);
    show("底牌", bottom, map);
}
private static void show(String name, List<Integer> list, Map<Integer, String> map) {
    //搜先看到名字
    System.out.print(name+":   ");

    for(Integer in:list){
        String value = map.get(in);
        System.out.print(value+"  ");
    }

    System.out.println();
}

运行结果展示如下:

结果
谢谢观看!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值