Java梭哈游戏部分实现代码

转载:https://www.cnblogs.com/jiqing9006/p/6107892.html
同时这段代码在李刚老师疯狂JAVA讲义这本书中也有

import java.util.*;

/**
 * Created by Jiqing on 2016/11/27.
 */
public class ShowHand { // 梭哈
    // 定义该游戏最多支持多少个玩家
    private final int PLAY_NUM = 5;
    // 定义扑克牌的花色和数值
    private String[] types = {"方块","草花","红心","黑桃"};
    private String[] values= {"2","3","4","5","6","7","8","9","10","J","Q","K","A"};
    // cards 扑克牌
    private List<String> cards = new LinkedList<String>();
    // 定义所有玩家
    private String[] players = new String[PLAY_NUM];

    // 玩家手上的扑克牌
    private List<String>[] playersCards = new List[PLAY_NUM];

    /**
     * 初始化扑克牌,放入52张扑克牌
     * 通过shuffle随机排序
     */
    public void initCards() {
        for(int i = 0 ; i < types.length ; i ++) {
            for (int j = 0;j<values.length;j++) {
                cards.add(types[i]+values[j]);
            }
        }
        // 随机排列
        Collections.shuffle(cards);
    }

    /**
     * 初始化玩家
     */
    public void initPlayer(String...names) {
        if (names.length > PLAY_NUM || names.length <2) {
            System.out.println("玩家数量不对");
            return;
        } else {
            for (int i = 0;i<names.length;i++){
                players[i] = names[i];
            }
        }
    }

    /**
     * 初始化玩家手中牌
     */
    public void initPlayerCards() {
        for (int i = 0;i<players.length;i++) {
            if (players[i] != null && !players[i].equals("")) {
                playersCards[i] = new LinkedList<String>();
            }
        }
    }

    /**
     * 输出全部扑克
     */
    public void showAllCards() {
        for (String card :cards) {
            System.out.println(card);
        }
    }

    /**
     * 派发扑克
     * @param first最先派给谁
     */
    public void deliverCard(String first) {
        int firstPos = ArrayUtils.search(players,first);
        // 依次给该玩家之后的人发牌
        for (int i = firstPos;i<PLAY_NUM;i++) {
            if (players[i] != null) {
                playersCards[i].add(cards.get(0)); // 获取第一张牌
                cards.remove(0);// 移除第一张牌
            }
        }

        // 依次给玩家之前的人发牌
        for (int i = 0 ; i<firstPos;i++) {
            if (players[i] != null) {
                playersCards[i].add(cards.get(0));
                cards.remove(0);
            }
        }
    }

    /**
     * 输出玩家手上的扑克牌
     *
     */
    public void showPlayerCards() {
        for (int i=0;i<PLAY_NUM;i++) {
            if (players[i] != null) {
                System.out.println(players[i] + ":");
                for (String card:playersCards[i]) {
                    System.out.print(card+"\t");
                }
            }
            System.out.print("\n");
        }

    }

    public static void main(String[] args) {
        ShowHand sh = new ShowHand();
        sh.initPlayer("电脑","纪庆");
        sh.initCards();
        sh.initPlayerCards();

        sh.showAllCards();
        System.out.println("--------------");
        sh.deliverCard("纪庆");
        sh.showPlayerCards();

        sh.deliverCard("电脑");
        sh.showPlayerCards();
    }

}

class ArrayUtils
{
    /**
     * 定义一个工具方法,工具方法从字符串数组中找到对应的字符串元素的位置
     * @param array 搜索的数组
     * @param target 搜索的字符串
     * @return 目标字符串出现的位置,-1表明找不到
     */
    public static int search(String[] array, String target)
    {
        for (int i = 0 ; i < array.length ; i++ )
        {
            if (array[i] != null && array[i].equals(target))
            {
                return i;
            }
        }
        return -1;
    }
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
一.扑克牌游戏 一副扑克牌去除大小王,剩余52张,A--K,红心,方块,黑桃,梅花四种花色。然后把这一副牌发给两个人,每人分得五张,比较这两人手中牌的大小。 大小的判定规则暂定如下: 牌型比较:同花顺>铁支>葫芦>同花>顺子>三条>二对>对子>散牌。 数字比较:A>K>Q>J>10>9>8 花式比较:黑桃>红桃>草花>方片 牌型说明: 同花顺:拥有五张连续性同花色的顺子。以A为首的同花顺最大。 铁支:四张相同数字的牌,外加一单张。比数字大小,「A」铁支最大 葫芦:由「三条」加一个「对子」所组成的牌,若别家也有此牌型,则比三条数字大小 同花:不构成顺子的五张同花色的牌。先比数字最大的单张,如相同再比第二支、依此类推 顺子:五张连续数字的牌组。 以A为首的顺子最大,如果大家都是顺子,比最大的一张牌,如果大小还一样就比这张牌的花式 三条:牌型由三张相同的牌组成,以A为首的三条最大 二对:牌型中五张牌由两组两张同数字的牌所组成。若遇相同则先比这副牌中最大的一对,如又相同再比第二对,如果还是一样,比大对子中的最大花式 对子:牌型由两张相同的牌加上三张单张所组成。如果大家都是对子,比对子的大小,如果对子也一样,比这个对子中的最大花色 散牌:单一型态的五张散牌所组成,不成对(二对),不成三条,不成顺(同花顺),不成同花,不成葫芦,不成铁支。先比最大一张牌的大小,如果大小一样,比这张牌的花色。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值