西北工业大学oj-扑克模拟

news/2024/12/22 10:06:40/

编程模拟斗地主的发牌过程。

一副扑克有54张牌,每张扑克包括花色(Suit)和牌面(Face)两个部分,花色包括:黑桃(spades)、红桃(hearts)、草花(clubs)、方块(diamonds) redblack。黑桃,红桃,草花和方块又有13张牌面:23……10JackJ)、QueenQ)、KingK)、Ared black 仅有1种牌面JokerJK)。每位玩家17张牌,剩余3张底牌

要求随机发5次牌,输出每次发牌后,每位玩家的牌和剩余的底牌:

示例输出:

玩家1:  黑桃_A     红桃_A     草花_2    ….

玩家2:  方块_K     草花_J     黑桃_Q   ….

玩家3:  黑桃_4      方块_10   草花_8   ….

底牌:    方块_2     小王          大王

java代码:

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;public class DouDiZhu {private static final String[] SUITS = {"黑桃", "红桃", "草花", "方块"};private static final String[] FACES = {"2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A"};private static final String[] JOKERS = {"大王", "小王"};public static void main(String[] args) {for (int i = 0; i < 5; i++) {dealCards();System.out.println();}}private static void dealCards() {List<String> deck = createDeck();Collections.shuffle(deck, new Random());List<String> player1 = new ArrayList<>();List<String> player2 = new ArrayList<>();List<String> player3 = new ArrayList<>();List<String> bottomCards = new ArrayList<>();for (int i = 0; i < 51; i++) {if (i % 3 == 0) {player1.add(deck.get(i));} else if (i % 3 == 1) {player2.add(deck.get(i));} else {player3.add(deck.get(i));}}bottomCards.add(deck.get(51));bottomCards.add(deck.get(52));bottomCards.add(deck.get(53));System.out.println("玩家1: " + player1);System.out.println("玩家2: " + player2);System.out.println("玩家3: " + player3);System.out.println("底牌: " + bottomCards);}private static List<String> createDeck() {List<String> deck = new ArrayList<>();for (String suit : SUITS) {for (String face : FACES) {deck.add(suit + "_" + face);}}deck.add("红_" + JOKERS[0]);deck.add("黑_" + JOKERS[1]);return deck;}
}
  1. 牌组创建

    createDeck 方法创建一个字符串列表表示扑克牌。包括 52 张普通牌和 2 张王。
  2. 洗牌

    使用 Collections.shuffle 随机打乱牌组顺序。
  3. 发牌

    前 51 张牌分给三位玩家。最后三张保留为底牌。
  4. 输出

    程序输出每位玩家的手牌和底牌。

c++代码:

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <ctime>void createDeck(std::vector<std::string>& deck) {const std::vector<std::string> suits = {"黑桃", "红桃", "草花", "方块"};const std::vector<std::string> faces = {"2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A"};const std::vector<std::string> jokers = {"大王", "小王"};for (const auto& suit : suits) {for (const auto& face : faces) {deck.push_back(suit + "_" + face);}}deck.push_back("红_" + jokers[0]);deck.push_back("黑_" + jokers[1]);
}void dealCards() {std::vector<std::string> deck;createDeck(deck);std::random_shuffle(deck.begin(), deck.end());std::vector<std::string> player1, player2, player3, bottomCards;for (int i = 0; i < 51; ++i) {if (i % 3 == 0) {player1.push_back(deck[i]);} else if (i % 3 == 1) {player2.push_back(deck[i]);} else {player3.push_back(deck[i]);}}bottomCards.push_back(deck[51]);bottomCards.push_back(deck[52]);bottomCards.push_back(deck[53]);std::cout << "玩家1: ";for (const auto& card : player1) std::cout << card << " ";std::cout << "\n玩家2: ";for (const auto& card : player2) std::cout << card << " ";std::cout << "\n玩家3: ";for (const auto& card : player3) std::cout << card << " ";std::cout << "\n底牌: ";for (const auto& card : bottomCards) std::cout << card << " ";std::cout << "\n";
}int main() {std::srand(unsigned(std::time(nullptr)));for (int i = 0; i < 5; ++i) {dealCards();std::cout << "\n";}return 0;
}


http://www.ppmy.cn/news/1520397.html

相关文章

聚餐地计算(华为od机考题)

一、题目 1.原题 小华和小为是很要好的朋友&#xff0c;他们约定周末一起吃饭。 通过手机交流&#xff0c; 他们在地图上选择了多个聚餐地点 &#xff08;由于自然地形等原因&#xff0c;部分聚餐地点不可达&#xff09;&#xff0c; 求小华和小为都能到达的聚餐地点有多少个…

10、Django Admin修改标题

admin from django.contrib import admin from .models import Category, Origin, Hero, Villain # 添加以下代码 admin.site.site_header "系统管理" admin.site.site_title "管理员界面" admin.site.index_title "欢迎来到这里&#xff…

分数阶微积分MATLAB计算

习题1 syms t z; Gamint(exp(-t)*t^(z-1),t,0,inf); I1subs(Gam,z,sym(1/2)), I2subs(Gam,z,sym(3/2)), I3subs(Gam,z,sym(5/2)), I4subs(Gam,z,sym(7/2))

Docker续8:使用docker-compose部署nmt项目

[rootlocalhost ~]# tree -L 3 pes 文件目录结构 pes ├── docker-compose.yml ├── haproxy │ └── haproxy.cfg ├── java │ ├── Dockerfile │ ├── jdk │ │ ├── bin │ │ ├── conf │ │ ├── include │ │ ├── jm…

注册安全分析报告:央视网

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

过去十年中,深度学习领域经历了许多重要的算法创新和突破。以下是一些关键的深度学习算法,按照时间顺序排列:

AlexNet (2012)&#xff1a;这是一个重要的卷积神经网络&#xff08;CNN&#xff09;&#xff0c;在2012年的ImageNet竞赛中取得了突破性的成绩。它的成功标志着深度学习在视觉任务中的潜力。 VGG (2014)&#xff1a;牛津大学的视觉几何组&#xff08;VGG&#xff09;提出了VG…

jupyter 安装新内核后报找不到已安装的包

按照参考资料1 在jupyter notebook 安装上新内核后&#xff0c;发现在命令行里可以导入已安装的包&#xff0c;但在jupyter notebook 无法导入对应的包 通过调试&#xff0c;发现jupyter 安装新内核的python 环境的执行文件不是新内核的python执行文件&#xff0c;而是conda 里…

前端学习笔记-Web APIs篇-02

事件监听(绑定&#xff09; 什么是事件&#xff1f; 事件是在编程时系统内发生的动作或者发生的事情【比如用户在网页上单击一个按钮 】 什么是事件监听&#xff1f; 就是让程序检测是否有事件产生&#xff0c;一旦有事件触发&#xff0c;就立即调用一个函数做出响应&#…