通过Java实现斗地主

功能:洗牌,发牌,对玩家手中的牌排序,看牌

package demo06;

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

/**
 *
 * @author Administrator
 *    实现模拟斗地主的功能
 *    1.组合牌
 *    2.洗牌
 *    3.发牌
 *    4.看牌
 */
public class DouDiZhu {
    public static void main(String[] args) {
        //1. 组合牌
        //创建Map集合,键是编号,值是牌
        HashMap<Integer, String> pooker=new HashMap<>();
        //创建List集合,存储编号
        ArrayList<Integer> pookerNumber=new ArrayList<>();
        //定义出13个点数的数组
        String[] numbers = {"2","A","K","Q","J","10","9","8",
                "7","6","5","4","3"};
        //定义四个花色数组
        String[] colors={"♥","♠","♣","♦"};
        //定义整数变量,作为键出现
        int index=2; //先避开大小王
        //遍历数组,花色+点数的组合存储到Map集合
        for(String number:numbers){
            for(String color:colors){
                pooker.put(index,color+number);
                pookerNumber.add(index);
                index++;
            }
        }
        //存储大王,和小王
        pooker.put(0, "大王");
        pookerNumber.add(0);
        pooker.put(1, "小王");
        pookerNumber.add(1);

        //洗牌,将牌的编号打乱
        Collections.shuffle(pookerNumber);

        //发牌功能,将牌编号,发给玩家集合,底牌集合
        ArrayList<Integer> player1=new ArrayList<>();
        ArrayList<Integer> player2=new ArrayList<>();
        ArrayList<Integer> player3=new ArrayList<>();
        ArrayList<Integer> bottom=new ArrayList<>();

        //发牌采用的是集合索引%3
        for(int i=0;i<pookerNumber.size();i++){
            //先将底牌做好
            if(i<3){
                //存到底牌去
                bottom.add(pookerNumber.get(i));
            }

            //对索引%3判断
            else if(i%3==0){
                //索引上的编号,发给玩家1
                player1.add(pookerNumber.get(i));
            }else if(i%3==1){
                //索引上的编号,发给玩家2
                player2.add(pookerNumber.get(i));
            }else if(i%3==2){
                //索引上的编号,发给玩家3
                player3.add(pookerNumber.get(i));
            }
        }
        //对玩家手中的编号排序
        Collections.sort(player1);
        Collections.sort(player2);
        Collections.sort(player3);
        //看牌,将玩家手中的编号,到Map集合中查找,根据键找值
        look("刘德华",player1,pooker);
        look("张学友",player2,pooker);
        look("黎明",player3,pooker);
        look("底牌",bottom,pooker);

    }
    public static void look(String name,ArrayList<Integer> player,HashMap<Integer, String> pooker){
        //遍历ArrayList集合,获取元素,作为键,到集合Map中找值
        System.out.println(name+":");
        for(Integer key:player){
            String value=pooker.get(key);
            System.out.print(value+" ");
        }
        System.out.println();
    }
}

原文地址:https://www.cnblogs.com/benjamin77/p/9125072.html

时间: 2024-10-18 20:31:04

通过Java实现斗地主的相关文章

Java模拟斗地主发牌和洗牌

package cn.itcast_04; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.TreeSet; /* * 思路: *      A:创建一个HashMap集合 *      B:创建一个ArrayList集合 *      C:创建花色数组和点数数组 *      D:从0开始往HashMap里面存储编号,并存储对应的牌 *   

java代码--斗地主

斗地主案例 *步骤:1.准备牌:      2.洗牌:   3.发牌:   4.排序:   5.看牌. 代码示例: public class DoudizhuTest { public static void main(String[] args) { //1.准备牌 //创建一个Map集合,储存洗好的牌和索引 Map<Integer, String> map = new HashMap<Integer, String>(); //创建一个List集合,用于存储牌的索引 List&

java斗地主

部分代码如下 Main.java package com; import java.awt.Color; import java.awt.Container; import java.awt.Point; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.ArrayList; import java.util.List; import java.util.Random

java斗地主游戏项目源码

部分代码如下Main.java package com; import java.awt.Color; import java.awt.Container; import java.awt.Point; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.ArrayList; import java.util.List; import java.util.Random;

2019-12-18

1. https://blog.csdn.net/xingxiupaioxue/article/details/840749832.Java 8系列之Stream的强大工具Collector https://blog.csdn.net/IO_Field/article/details/549716083.Java8-对map排序 https://www.cnblogs.com/fengkunangel/p/10507916.html4.Java8 教程第五章之Streams Collectors

java 18 - 12 模拟斗地主洗牌、发牌,并对发的牌进行排序

1 /* 2 模拟斗地主的发牌功能(发牌完毕后发到手上的牌是有顺序的) 3 分析: 4 A:创建一个HashMap集合 5 B:创建一个ArrayList集合 6 C:创建两个字符串,一个是花色,一个是牌的数字 (发牌得有一盒牌) 7 为了方便以后的排序,创建这两个字符串的时候,按照大小顺序排列(斗地主中的大小顺序) 8 大小王除外 9 D:把这两个字符串放进HashMap集合中(拼接一起 花色+牌号) 同时给每个放进去牌进行编码0--52并存储 10 同时也给ArrayList集合中存储编码,

Java集合练习:斗地主游戏

这是一个模拟斗地主的小游戏,最后看到的牌型是经过排序的,具体代码和解释如下: package cn.poker_test; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.TreeSet; /* * 模拟斗地主小游戏 * * 思路: * A:创建一个HashMap集合 * B:创建一个ArrayList集合 * C:创建花色数组和点数数组 *

java之实例斗地主(集合)

public class CollectionTest { /**  * 玩斗地主的三个步骤:  * A 买牌  * B 洗牌  * C 发牌  * D 看底牌  */ public static void main(String[] args) { String[] color={"黑桃","红桃","梅花","方块"};  String[] numbers={"A","2",&quo

Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)

规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; public class DouDiZhu { public static void main(String[] args) { // 创建Map集合,键