广告位联系
返回顶部
分享到

java实现模仿斗地主发牌的代码

java 来源:互联网搜集 作者:秩名 发布时间:2019-12-11 10:40:15 人浏览
摘要

分析 这是一个模仿斗地主发牌的例子; 按照斗地主的规则,完成洗牌发牌的动作。 具体规则: 用0~53分别对应相应的花色和牌面值; 用shuffle随机打乱排序好的数字,起到洗牌的作用; 使用54张牌打乱顺序,三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张

分析

这是一个模仿斗地主发牌的例子;
按照斗地主的规则,完成洗牌发牌的动作。 具体规则:

  • 用0~53分别对应相应的花色和牌面值;
  • 用shuffle随机打乱排序好的数字,起到洗牌的作用;


使用54张牌打乱顺序,三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌。

实现方式

准备牌:

牌可以设计为一个ArrayList,每个字符串为一张牌。 每张牌由花色数字两部分组成,我们可以使用花色集合与数字集合嵌套迭代完成每张牌的组装。 牌由Collections类的shuffle方法进行随机排序。

发牌:

将每个人以及底牌设计为ArrayList,将最后3张牌直接存放于底牌,剩余牌通过对3取模依次发牌。

看牌:

直接打印每个集合

代码实现
 

import java.util.ArrayList;
import java.util.Collections;
public class Poker {
  public static void main(String[] args) {
    /*
    * 1: 准备牌操作
    */
    //1.1 创建牌盒 将来存储牌面的
    ArrayList<String> pokerBox = new ArrayList<String>();
    //1.2 创建花色集合
    ArrayList<String> colors = new ArrayList<String>();
    //1.3 创建数字集合
    ArrayList<String> numbers = new ArrayList<String>();
    //1.4 分别给花色 以及 数字集合添加元素
    colors.add("♥");
    colors.add("♦");
    colors.add("♠");
    colors.add("♣");
    for(int i = 2;i<=10;i++){
      numbers.add(i+"");
    }
    numbers.add("J");
    numbers.add("Q");
    numbers.add("K");
    numbers.add("A");
    //1.5 创造牌 拼接牌操作
    // 拿出每一个花色 然后跟每一个数字 进行结合 存储到牌盒中
    for (String color : colors) {
      //color每一个花色 guilian
      //遍历数字集合
      for(String number : numbers){
        //结合
        String card = color+number;
        //存储到牌盒中
        pokerBox.add(card);
      }
    }
    //1.6大王小王
    pokerBox.add("小☺");
    pokerBox.add("大☠");  
    // System.out.println(pokerBox);
    //洗牌 是不是就是将 牌盒中 牌的索引打乱
    // Collections类 工具类 都是 静态方法
    // shuffer方法 
    /*
     * static void shuffle(List<?> list)
     *   使用默认随机源对指定列表进行置换。
     */
    //2:洗牌
    Collections.shuffle(pokerBox);
    //3 发牌
    //3.1 创建 三个 玩家集合 创建一个底牌集合
    ArrayList<String> player1 = new ArrayList<String>();
    ArrayList<String> player2 = new ArrayList<String>();
    ArrayList<String> player3 = new ArrayList<String>();
    ArrayList<String> dipai = new ArrayList<String>();  
    //遍历 牌盒 必须知道索引 
    for(int i = 0;i<pokerBox.size();i++){
      //获取 牌面
      String card = pokerBox.get(i);
      //留出三张底牌 存到 底牌集合中
      if(i>=51){//存到底牌集合中
        dipai.add(card);
      } else {
        //玩家1  %3 ==0
        if(i%3==0){
          player1.add(card); 
        }else if(i%3==1){//玩家2
          player2.add(card); 
        }else{//玩家3
          player3.add(card); 
        }
      }
    }
    //看看
    System.out.println("令狐冲:"+player1);
    System.out.println("田伯光:"+player2);
    System.out.println("绿竹翁:"+player3);
    System.out.println("底牌:"+dipai); 
 }  
}


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/Luojun13Class/article/details/86583138
相关文章
  • SpringBoot自定义错误处理逻辑介绍

    SpringBoot自定义错误处理逻辑介绍
    1. 自定义错误页面 将自定义错误页面放在 templates 的 error 文件夹下,SpringBoot 精确匹配错误信息,使用 4xx.html 或者 5xx.html 页面可以打印错误
  • Java实现手写一个线程池的代码

    Java实现手写一个线程池的代码
    线程池技术想必大家都不陌生把,相信在平时的工作中没有少用,而且这也是面试频率非常高的一个知识点,那么大家知道它的实现原理和
  • Java实现断点续传功能的代码

    Java实现断点续传功能的代码
    题目实现:网络资源的断点续传功能。 二、解题思路 获取要下载的资源网址 显示网络资源的大小 上次读取到的字节位置以及未读取的字节
  • 你可知HashMap为什么是线程不安全的
    HashMap 的线程不安全 HashMap 的线程不安全主要体现在下面两个方面 在 jdk 1.7 中,当并发执行扩容操作时会造成环形链和数据丢失的情况 在
  • ArrayList的动态扩容机制的介绍

    ArrayList的动态扩容机制的介绍
    对于 ArrayList 的动态扩容机制想必大家都听说过,之前的文章中也谈到过,不过由于时间久远,早已忘却。 所以利用这篇文章做做笔记,加
  • JVM基础之字节码的增强技术介绍

    JVM基础之字节码的增强技术介绍
    字节码增强技术 在上文中,着重介绍了字节码的结构,这为我们了解字节码增强技术的实现打下了基础。字节码增强技术就是一类对现有字
  • Java中的字节码增强技术

    Java中的字节码增强技术
    1.字节码增强技术 字节码增强技术就是一类对现有字节码进行修改或者动态生成全新字节码文件的技术。 参考地址 2.常见技术 技术分类 类
  • Redis BloomFilter布隆过滤器原理与实现

    Redis BloomFilter布隆过滤器原理与实现
    Bloom Filter 概念 布隆过滤器(英语:Bloom Filter)是1970年由一个叫布隆的小伙子提出的。它实际上是一个很长的二进制向量和一系列随机映射
  • Java C++算法题解leetcode801使序列递增的最小交换次

    Java C++算法题解leetcode801使序列递增的最小交换次
    题目要求 思路:状态机DP 实现一:状态机 Java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 class Solution { public int minSwap(int[] nums1, int[] nums2) { int n
  • Mybatis结果集映射与生命周期介绍

    Mybatis结果集映射与生命周期介绍
    一、ResultMap结果集映射 1、设计思想 对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了 2、resultMap的应用场
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计