文档章节

斗地主JAVA简要实现

xxj123gogo
 xxj123gogo
发布于 2017/08/12 02:28
字数 337
阅读 184
收藏 0

#程序员薪资揭榜#你做程序员几年了?月薪多少?发量还在么?>>>

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.TreeSet;

public class ddzDemo2 {
    /**
     * 斗地主--最终版
     * 
     * @param args
     *            定义牌 装牌 洗牌 发牌 看牌
     */

    public static void main(String[] args) {
        // 按从小到大存放牌
        HashMap<Integer, String> hmcard = new HashMap<Integer, String>();
        
        // 定义牌的序号
        ArrayList<Integer> indexcard = new ArrayList<Integer>();
        
        String[] colorCard = { "♣", "♦", "♥", "♠" };
        String[] digitCard = { "3", "4", "5", "6", "7", "8", "9", "10", "J",
                "Q", "K", "A", "2" };

        // 装牌
        int index = 0;
        for (String d : digitCard) {
            for (String c : colorCard) {
                hmcard.put(index, c.concat(d));
                indexcard.add(index);
                index++;
            }
        }
        hmcard.put(index, "小王");
        indexcard.add(index);
        index++;
        hmcard.put(index, "大王");
        indexcard.add(index);

        // 洗牌
        Collections.shuffle(indexcard);

        // 发牌 TressSet有序
        TreeSet<Integer> player1 = new TreeSet<Integer>();
        TreeSet<Integer> player2 = new TreeSet<Integer>();
        TreeSet<Integer> player3 = new TreeSet<Integer>();
        TreeSet<Integer> hole = new TreeSet<Integer>();
        for (int i = 0; i < indexcard.size(); i++) {
            if (i > indexcard.size() - 3 - 1) {
                hole.add(indexcard.get(i));
            } else if (i % 3 == 0) {
                player1.add(indexcard.get(i));
            } else if (i % 3 == 1) {
                player2.add(indexcard.get(i));
            } else if (i % 3 == 2) {
                player3.add(indexcard.get(i));
            }
        }

        // 看牌
        checkcard("农民1", player1, hmcard);
        checkcard("农民2", player2, hmcard);
        checkcard("地主", player3, hmcard);
        checkcard("hole", hole, hmcard);
    }

    public static void checkcard(String name, TreeSet<Integer> pl,
            HashMap<Integer, String> hmcd) {
        StringBuilder sb = new StringBuilder();
        for (int p : pl) {
            sb.append(hmcd.get(p) + " ");
        }
        if (name.equals("hole")) {
            System.out.println("底牌是: " + sb);
        } else {
            System.out.println(name + "的牌是: " + sb);
        }

    }
}

运行:

农民1的牌是: ♣3 ♠3 ♣4 ♥4 ♠4 ♥8 ♠8 ♦9 ♠9 ♠10 ♦J ♥J ♣Q ♣K ♦A ♠A ♣2 
农民2的牌是: ♥3 ♣5 ♥5 ♥6 ♠6 ♦7 ♣8 ♥9 ♦10 ♣J ♠J ♠Q ♥K ♠K ♣A ♠2 小王 
地主的牌是: ♦3 ♦4 ♦5 ♠5 ♣6 ♣7 ♥7 ♠7 ♦8 ♣10 ♥10 ♦Q ♥Q ♦K ♥A ♦2 大王 
底牌是: ♦6 ♣9 ♥2 

 

© 著作权归作者所有

xxj123gogo
粉丝 1
博文 67
码字总数 86328
作品 0
其它
程序员
私信 提问
加载中

评论(0)

ansatsing/QQLandlords

为什么要搞这样一个项目 满足自己的java网络多线程编程的欲望!因为之前一直都是搞web开发,服务器和客户端数据交流人家web服务器早就给你搞好了,比如tomcat,jetty...等等,其实之前脑子里就...

ansatsing
2019/02/15
0
0
使用Java实现简单的斗地主案例

使用Java实现简单的斗地主案例 案例说明:使用Java实现简单的斗地主洗牌发牌的操作; 具体规则: 共有54张牌,顺序打乱; 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后留三张为底牌(地...

淡哈哈
05/09
0
0
java高级---->Java动态代理的原理

  Java动态代理机制的出现,使得 Java 开发人员不用手工编写代理类,只要简单地指定一组接口及委托类对象,便能动态地获得代理类。代理类会负责将所有的方法调用分派到委托对象上反射执行,...

huhx
2016/04/06
0
0
Java自学路线图之Java进阶自学

Java自学路线图的第二阶段是Java语言进阶自学,在自学了第一阶段的Java基础自学后,大家对Java语言编程有了初步的了解和认识,建议在第一部分自学后整理一下自己的自学思路,思考自己在自学J...

osc_6b6pwh7r
03/15
21
0
JDK,JRE和JVM之间的区别

JDK,JRE和JVM之间的区别 易百教程移动端:请扫描本页面底部(右侧)二维码并关注微信公众号,回复:"教程" 选择相关教程阅读或直接访问:http://m.yiibai.com 好多开发者学习 Java 编程有若干...

LYQ1990
2018/07/18
92
0

没有更多内容

加载失败,请刷新页面

加载更多

腾讯副总裁魏颖:提瓢入市,倚杖而归

  魏颖,腾讯公司副总裁,2008 年加入腾讯,全面负责公司薪酬福利、绩效管理、员工关系以及海外业务人力资源。   ————————   很多人对人力资源(HR)工作的理解就是一些人事流...

alkcendkljk
29分钟前
13
0
OSChina 周二乱弹 —— 我要一份儿大姐姐的爱

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @Cobbage :分享赵雷的单曲《阿刁 (Diao)》: 《阿刁 (Diao)》- 赵雷 手机党少年们想听歌,请使劲儿戳(这里) @喵星人123 :昨天睡到半夜 突然...

小小编辑
30分钟前
11
0
window下 mongodb开启用户名和密码 权限

在默认情况下,mongod是监听在127.0.0.1之上的,任何客户端都可以直接连接27017,且没有认证。 好处是,用户可以即时上手,不用担心被一堆配置弄的心烦意乱。 坏处是,公网服务器搭建MongoDB...

东东笔记
今天
9
0
数据倾斜

数据倾斜: 两种数据倾斜发生的现象: 80%情况下都发生挂了,只有极少20%情况下能把task执行完成 窄依赖:结构简单,如果发生数据丢失,方便查找丢失的数据 宽依赖:结构复杂,如何发生数据丢...

七宝1
今天
20
0
我的jdk源码(十一):ArrayList

一、概述 ArrayList类是AbstractList的子类,实现了具体的add(), set(), remove()等方法。它是一个可调整大小的数组可以用来存放各种形式的数据。 二、源码分析 (1) 类的声明,源码如下: ...

Java觉浅
昨天
24
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部