当前位置: 首页 > article >正文

模拟斗地主

需求:通过程序实现斗地主过程中的洗牌,发牌,看牌

        思路:

                创建一个牌盒,也就是定义一个集合对象,用ArrayList集合实现

                往牌盒里装牌

                洗牌,也就是把牌打散,用Collections的shuffle()方法实现

                发牌,也就是遍历集合,给三个玩家发牌

                看牌,也就是三个玩家分别遍历自己的牌

代码实现:

package com.aynu4;

//需求:通过程序实现斗地主过程中的洗牌,发牌,看牌
//        思路:
//            创建一个牌盒,也就是定义一个集合对象,用ArrayList集合实现
//            往牌盒里装牌
//            洗牌,也就是把牌打散,用Collections的shuffle()方法实现
//            发牌,也就是遍历集合,给三个玩家发牌
//            看牌,也就是三个玩家分别遍历自己的牌

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

public class PokerDemo {
    public static void main(String[] args) {

        //            创建一个牌盒,也就是定义一个集合对象,用ArrayList集合实现
        ArrayList<String> array = new ArrayList<String>();

        //          往牌盒里装牌
        /*
         *   ♦2,♦3,..♦K,♦A
         *   ♣2,......
         *   ♥2......
         *   ♠2......
         *   大王,小王
         * */
        //定义花色数组
        String[] colors = {"♦", "♣", "♥", "♠"};
        //定义点数数组
        String[] numbers = {"2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A"};
        for (String color : colors) {
            for (String number : numbers) {
                array.add(color + number);
            }
        }
        //大王,小王
        array.add("小王");
        array.add("大王");

        //            洗牌,也就是把牌打散,用Collections的shuffle()方法实现
        Collections.shuffle(array);
//        System.out.println(array);

        //            发牌,也就是遍历集合,给三个玩家发牌
        ArrayList<String> lqxArray = new ArrayList<String>();
        ArrayList<String> lyArray = new ArrayList<String>();
        ArrayList<String> fqyArray = new ArrayList<String>();
        ArrayList<String> dpArray = new ArrayList<String>();

        for (int i = 0; i < array.size(); i++) {
            String poker = array.get(i);
            if (i >= array.size() - 3) {
                dpArray.add(poker);
            } else if (i % 3 == 0) {
                lqxArray.add(poker);
            } else if (i % 3 == 1) {
                lyArray.add(poker);
            } else if (i % 3 == 2) {
                fqyArray.add(poker);

            }
        }

//        看牌,也就是三个玩家分别遍历自己的牌
        //调用看牌的方法
        lookpoker("林青霞", lqxArray);
        lookpoker("柳岩", lyArray);
        lookpoker("风清扬", fqyArray);
        lookpoker("底牌", dpArray);
    }

    //看牌的方法
    public static void lookpoker(String name, ArrayList<String> array) {
        System.out.print(name + "的牌是:");
        for (String poker : array) {
            System.out.print(poker + " ");
        }
        System.out.println();
    }
}

林青霞的牌是:♠2 ♠J ♥5 ♥J ♣10 ♥K ♣2 ♠7 大王 ♣3 ♥6 ♠Q ♥9 ♦2 ♣J ♦5 ♠3 
柳岩的牌是:♥10 ♦A 小王 ♦K ♠5 ♦J ♣A ♥4 ♦3 ♠4 ♥3 ♥2 ♦7 ♥A ♦8 ♦Q ♦10 
风清扬的牌是:♣6 ♦6 ♣Q ♣7 ♠9 ♠8 ♣5 ♠A ♠K ♦4 ♣K ♥7 ♣9 ♥8 ♦9 ♣4 ♠6 
底牌的牌是:♠10 ♣8 ♥Q 


http://www.kler.cn/a/3654.html

相关文章:

  • (三)线性代数之二阶和三阶行列式详解
  • 第五篇 vue3 ref 与 reactive 对比
  • 论文笔记(六十三)Understanding Diffusion Models: A Unified Perspective(一)
  • win32汇编环境,对多行编辑框添加或删除文本
  • 常用排序算法之插入排序
  • Tcl教程
  • 【c++】:list模拟实现“任意位置插入删除我最强ƪ(˘⌣˘)ʃ“
  • 【Linux】进程理解与学习Ⅲ-环境变量
  • Centos Linux 正确安装 Redis 的方式
  • C++快速排序算法(详解)
  • 【李宏毅】-各种各样的self-attention
  • Linux上搭建Discuz论坛
  • 软件测试基础篇
  • QCefView编译配置(Windows-MSVC)(11)
  • jwt 学习笔记
  • ChatGPT常用开源项目汇总
  • 动态代理原理
  • 【备战蓝桥杯】----01背包问题(动态规划)
  • vue3 自定义message弹窗
  • Linux C/C++并发编程实战(5)内存屏障是什么?
  • 【数据结构】千字深入浅出讲解栈(附原码 | 超详解)
  • Centos7.6安装19C报错CRS-2674 CRS-2632
  • mqtt协议
  • 走进二叉树的世界 ———性质讲解
  • 一种LCD屏闪问题的调试
  • C语言小程序:通讯录(静态版)