Java实现斗地主-做牌以及对牌排序

卡牌类

java 复制代码
public class Card {
    private String size;//大小
    private String color;//花色
    private int value;//权值

    public Card() {
    }

    public Card(String size, String color, int value) {
        this.size = size;
        this.color = color;
        this.value = value;
    }


    public String toString(){
        return size+color;
    }

    /**
     * 获取
     * @return size
     */
    public String getSize() {
        return size;
    }

    /**
     * 设置
     * @param size
     */
    public void setSize(String size) {
        this.size = size;
    }

    /**
     * 获取
     * @return color
     */
    public String getColor() {
        return color;
    }

    /**
     * 设置
     * @param color
     */
    public void setColor(String color) {
        this.color = color;
    }

    /**
     * 获取
     * @return value
     */
    public int getValue() {
        return value;
    }

    /**
     * 设置
     * @param value
     */
    public void setValue(int value) {
        this.value = value;
    }
}

玩家类

java 复制代码
import java.util.List;

public class Player {
    private String name;// 玩家姓名
    private List<Card> cards;// 玩家手牌

    public Player() {
    }

    public Player(String name, List<Card> cards) {
        this.name = name;
        this.cards = cards;
    }

    /**
     * 获取
     * @return name
     */
    public String getName() {
        return name;
    }

    /**
     * 设置
     * @param name
     */
    public void setName(String name) {
        this.name = name;
    }

    /**
     * 获取
     * @return cards
     */
    public List<Card> getCards() {
        return cards;
    }

    /**
     * 设置
     * @param cards
     */
    public void setCards(List<Card> cards) {
        this.cards = cards;
    }

    public String toString() {
        return "Player{name = " + name + ", cards = " + cards + "}";
    }
}

游戏类(程序入口)

java 复制代码
import java.util.*;

public class game {
    public static void main(String[] args) {
        //1.准备花色
        String[] colors = {"♥", "♠", "♣", "♦"};
        //2.准备点数
        String[] numbers = {"3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A", "2"};
        //3.准备牌
        List<Card> cards = new ArrayList<>();
        //4.添加牌 count代表权值
        int count = 0;
        for (String number : numbers) {
            count++;
            for (String color : colors) {
                cards.add(new Card(color, number, count));
            }
        }
        //5.添加大王和小王
        cards.add(new Card("🃏", "", 14));
        cards.add(new Card("👲", "", 15));
        System.out.println(cards);

        //6.洗牌
        Collections.shuffle(cards);//比for循环更优雅
        System.out.println(cards);

        //7.发牌,并且要留3张底牌
        List<Player> players = new ArrayList<>();
        players.addAll(Arrays.asList(new Player("张三", new ArrayList<>()),
        new Player("李四", new ArrayList<>()), new Player("王五", new ArrayList<>())));
        for (int i = 0; i < cards.size()-3; i++) {
            if (i%3==0){
                //如果下标取余是0,则给张三发一张
                players.get(0).getCards().add(cards.get(i));
            }else if (i%3==1){
                //如果下标取余是1,则给李四发一张
                players.get(1).getCards().add(cards.get(i));
            }else {
                //如果下标取余是2,则给王五发一张
                players.get(2).getCards().add(cards.get(i));
            }
        }
        //通过随机数把地主牌放到对应的人里面,如果随机数是0,则张三当地主。
        Random random = new Random();
        int index = random.nextInt(3);
        players.get(index).getCards().addAll(cards.subList(cards.size()-3,cards.size()));
        //根据stream流对玩家的牌进行排序
        players.forEach(player -> {
            player.getCards().sort(Comparator.comparingInt(Card::getValue));
            System.out.println(player);
        });

    }
}

程序运行结果

小结

1.Collections.shuffle(cards);//比for循环更优雅代码量少,同样比stream流优雅,stream不会对对象本身操作,因此排序后还要再重新赋值,故这里不选用stream流实现排序。

2.通过对card类封装value属性可以很好的解决斗地主2比3大的问题,这里体现了面向对象的思想。

相关推荐
JAVA百练成神31 分钟前
Java引用RabbitMQ快速入门
java·rabbitmq·java-rabbitmq
元亓亓亓39 分钟前
Java后端开发day42--IO流(二)--字符集&字符流
java·开发语言
一刀到底2111 小时前
idea内存过低 设置 Maximum Heap Size 终极解决方案
java·ide·intellij-idea
S01d13r2 小时前
LeetCode 解题思路 45(分割等和子集、最长有效括号)
算法·leetcode·职场和发展
振鹏Dong2 小时前
Java基础问题——八股盛宴 | 3w字分享
java
JH30732 小时前
【SpringBoot】SpringBoot中使用AOP实现日志记录功能
java·spring boot·后端
学java的cc2 小时前
Spring AI快速入门
java·大数据·spring
豆沙沙包?3 小时前
2025年- H17-Lc125-73.矩阵置零(矩阵)---java版
java·线性代数·矩阵
理想奋斗中3 小时前
【LeetCode Hot100 | 每日刷题】二叉树的层序遍历
算法·leetcode·bfs
钦拆大仁4 小时前
华为云短信接入实现示例
java·华为云