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

综合案例:斗地主

综合案例:斗地主

1.程序概述

这是一个模拟斗地主游戏发牌过程的C语言程序,实现了扑克牌的初始化、洗牌和发牌功能。

2.功能需求

2.1 扑克牌定义
  • 使用结构体 Card 表示一张牌,包含:
    • 花色属性suit(0-3表示普通花色♥♠♦♣,4表示小王,5表示大王)
    • 点数属性rank(0-12对应3-A,2,-1表示大小王)
2.2 主要功能
  1. 初始化牌组
  • 创建包含54张牌的牌组(52张普通牌+2张王牌)
  • 普通牌按花色(♠,♥,♣,♦)和点数(3-2)排列
  1. 洗牌功能

    • 使用随机数对牌组进行随机排序
    • 确保每次运行洗牌结果不同(基于时间种子)
  2. 发牌功能

    • 将洗好的牌发给3个玩家
    • 每个玩家17张牌
    • 剩余3张作为底牌
  3. 显示功能

    • 打印每个玩家的手牌 打印底牌
    • 打印底牌

3.数据结构

  • suits[] : 存储4种花色符号的字符串数组
  • ranks[]: 存储13个点数等级的字符串数组
  • jokers[] : 存储大小王描述的字符串数组
  • Card 结构体: 表示单张牌的数据结构
  • 牌组数组: deck[54]
  • 玩家手牌数组: player1[17] , player2[17], player3[17]
  • 底牌数组: bottomCards[3]

4.用户交互

程序运行后自动完成以下流程:

  1. 初始化牌组
  2. 洗牌
  3. 发牌
  4. 显示发牌结果(3个玩家的手牌和底牌)

5.输出格式

  • 普通牌显示格式:花色+点数(如"♠ 3")
  • 王牌显示格式:“小王"或"大王”
  • 玩家手牌按顺序显示,每张牌用空格分隔
  • 底牌同样格式显示

6.代码演示

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <math.h>// 定义扑克牌的花色和点数
const char *suits[] = {"♠","♥","♣","♦"}; // 花色
const char *ranks[] = {"3","4","5","6","7","8","9","10","J","Q","K","A","2"}; // 点数
const char *joker[] = {"小王","大王"}; // 大小王// 定义牌的结构体
typedef struct
{int suit; // 花色(0-3:普通牌,4:小王,5:大王)int rank; // 点数(0-12:普通牌,-1:大小王)
}Card;// 声明函数原型
void initDeck(Card *deck);
void shuffeDeck(Card *deck, int len);
void dealCards(Card *deck, Card *player1, Card *player2, Card *player3, Card *bottomCards);
void printCard(Card card);int main(int argc,char *argv[])
{Card deck[54]; // 一副牌(54张,包含大小王)Card player1[17], player2[17], player3[17]; // 三个玩家的手牌Card bottomCards[3]; // 底牌// 初始化牌initDeck(deck);// 洗牌shuffeDeck(deck, 54);// 发牌dealCards(deck, player1, player2, player3, bottomCards);// 打印玩家手牌和底牌int i;printf("玩家1的手牌:");for(i = 0; i < 17; i++) printCard(player1[i]);printf("\n");printf("玩家2的手牌:");for(i = 0; i < 17; i++) printCard(player2[i]);printf("\n");printf("玩家3的手牌:");for(i = 0; i < 17; i++) printCard(player3[i]);printf("\n");printf("底牌:");for(i = 0; i < 3; i++) printCard(bottomCards[i]);printf("\n");return 0;
}/**
* 初始化一副牌(54张,包含大小王)
*/
void initDeck(Card *deck)
{// 定义一个索引int index = 0;// 初始化普通牌for(int suit = 0; suit < 4; suit++) // 遍历花色{for(int rank = 0; rank < 13; rank++) // 遍历点数{deck[index].suit = suit; // 每一张牌的花色(索引)deck[index].rank = rank; // 每一张牌的点数(索引)index++;}}// 初始化大小王deck[index].suit = 4; // 小王deck[index].rank = -1;index++;deck[index].suit = 5; // 大王deck[index].rank = -1;
}/**
* 洗牌(打乱牌序)
*/
void shuffeDeck(Card *deck, int len)
{// 设置随机种子srand(time(NULL));// 洗牌for(int i = 0; i < len; i++){int j = rand() % len; // 索引 0 ~ 53// 将随机出来的牌序和原本的排序交换Card temp = deck[i]; deck[i] = deck[j];deck[j] = temp;  }
}
/**
* 发牌(3个玩家各自17张牌,最后3张牌作为底牌)
*/
void dealCards(Card *deck, Card *player1, Card *player2, Card *player3, Card *bottomCards)
{int index = 0;// 给玩家发牌for(int i = 0; i < 17; i++){player1[i] = deck[index++]; // 玩家1 等价于 deck[index]; index++;player2[i] = deck[index++]; // 玩家2player3[i] = deck[index++]; // 玩家3}// 最后3张留作底牌for(int i = 0; i < 3; i++){bottomCards[i] = deck[index++];}
}/**
* 打印牌(根据牌的索引,显示对应的字符串)
*/
void printCard(Card card)
{if(card.suit == 4 || card.suit == 5){// 大小王printf("%s ", joker[card.suit - 4]);}else{// 普通牌printf("%s %s ", suits[card.suit], ranks[card.rank]);}
}

运行效果:

在这里插入图片描述

相关文章:

综合案例:斗地主

综合案例&#xff1a;斗地主 1.程序概述 这是一个模拟斗地主游戏发牌过程的C语言程序&#xff0c;实现了扑克牌的初始化、洗牌和发牌功能。 2.功能需求 2.1 扑克牌定义 使用结构体 Card 表示一张牌&#xff0c;包含&#xff1a; 花色属性suit&#xff08;0-3表示普通花色♥…...

前端组件推荐 Swiper 轮播与 Lightbox 灯箱组件深度解析

在互联网产品不断迭代升级的今天&#xff0c;用户对于页面交互和视觉效果的要求越来越高。想要快速打造出吸睛又实用的项目&#xff0c;合适的组件必不可少。今天就为大家推荐两款超好用的组件 ——Swiper 轮播组件和 Lightbox 灯箱组件&#xff0c;轻松解决你的展示难题&#…...

解密并下载受DRM保护的MPD(DASH流媒体)加密视频

要解密并下载受DRM保护的MPD&#xff08;DASH流媒体&#xff09;加密视频&#xff0c;需结合技术工具与合法授权。以下是关键方法与步骤&#xff1a; 一、工具与技术要求 Widevine-DL 这是一个开源Python工具&#xff0c;支持下载和解密Widevine DRM保护的MPD内容。它依赖ffmpe…...

数据可视化有哪些步骤?2025高效落地指南

分享大纲 1、科学框架&#xff1a;从数据到洞察落地 2、可视化实战&#xff1a;捷码快速搭建专业大屏 3、关键避坑指南 根据IBM研究&#xff0c;规范的数据可视化流程&#xff0c;可以使得数据可视化搭建效率提升41%。那有标准的数据可视化搭建方法是哪些呢&#xff1f;本文将借…...

Deepfashion2 数据集使用笔记

目录 数据类别: 筛选类别数据: 验证精度筛选前2个类别: 提取类别数据 可视化类别数据: Deepfashion2 的解压码 旋转数据增强 数据类别: 类别含义: Class idx类别名称英文名称0短上衣short sleeve top1长上衣long sleeve top2短外套short sleeve outwear3长外套lo…...

Dify知识库下载小程序

一、Dify配置 1.查看或创建知识库的API 二、下载程序配置 1. 安装依赖resquirements.txt ######requirements.txt##### flask2.3.3 psycopg2-binary2.9.9 requests2.31.0 python-dotenv1.0.0#####安装依赖 pip3 install -r requirements.txt -i https://pypi.tuna.tsinghua.…...

匀速旋转动画的终极对决:requestAnimationFrame vs CSS Animation

引言&#xff1a;旋转动画的隐藏陷阱 在现代Web开发中&#xff0c;实现一个流畅的无限旋转动画似乎是个简单任务。但当我深入探究时&#xff0c;发现这个看似基础的需求背后隐藏着性能陷阱、数学精度问题和浏览器渲染机制的深层奥秘。本文将带你从一段常见的requestAnimationF…...

数据库中求最小函数依赖集-最后附解题过程

今天来攻克数据库设计里一个超重要的知识点 —— 最小函数依赖集。对于刚接触数据库的小白来说&#xff0c;这概念可能有点绕&#xff0c;但别担心&#xff0c;咱们一步步拆解&#xff0c;轻松搞定&#x1f4aa;&#xff01; &#xff08;最后fuyou&#xff09; 什么是最小函数…...

嵌入式系统中常用的开源协议

目录 1、GNU通用公共许可证&#xff08;GPL&#xff09; 2、GNU宽松通用公共许可证&#xff08;LGPL&#xff09; 3、MIT许可证 4、Apache许可证2.0 5、BSD许可证 6、如何选择合适的协议 在嵌入式系统开发中&#xff0c;开源软件的使用已成为主流趋势。从物联网设备到汽车…...

MySQL 索引底层原理剖析:B+ 树结构、索引创建维护与性能优化策略全解读

引言 在 MySQL 数据库的世界里&#xff0c;索引是提升查询性能的关键利器。然而&#xff0c;很多开发者虽然知道索引的重要性&#xff0c;但对于索引背后的底层原理却知之甚少。本文将深入 MySQL 索引的底层实现&#xff0c;剖析 B 树的结构特点&#xff0c;以及如何利用这些知…...

系统架构设计论文

disstertation 软考高级-系统架构设计师-论文&#xff1a;论文范围&#xff08;十大知识领域&#xff09;、历年论题、预测论题及论述过程、论文要点、论文模板等。 —— 2025 年 4 月 4 日 甲辰年三月初七 清明 目录 disstertation1、论文范围&#xff08;十大核心领域&#x…...

第二篇:Liunx环境下搭建PaddleOCR识别

第二篇&#xff1a;Liunx环境下搭建Paddleocr识别 一&#xff1a;前言二&#xff1a;安装PaddleOCR三&#xff1a;验证PaddleOCR是否安装成功 一&#xff1a;前言 PaddleOCR作为业界领先的多语言开源OCR工具库&#xff0c;其核心优势在于深度整合了百度自主研发的飞桨PaddlePa…...

图片上传问题解决方案与实践

一、问题描述 在校园二手交易平台中&#xff0c;上传商品图片后出现以下异常情况&#xff1a; 图片访问返回404错误&#xff0c;无法正常加载服务器错误识别文件类型为text/plain图片 URL 路径存在不完整问题 二、原因分析 &#xff08;一&#xff09;静态资源访问配置问题…...

复杂业务场景下 JSON 规范设计:Map<String,Object>快速开发 与 ResponseEntity精细化控制HTTP 的本质区别与应用场景解析

Moudle 1 Json使用示例 在企业开发中&#xff0c;构造 JSON 格式数据的方式需兼顾 可读性、兼容性、安全性和开发效率&#xff0c;以下是几种常用方式及适用场景&#xff1a; 一、直接使用 Map / 对象转换&#xff08;简单场景&#xff09; 通过 键值对集合&#xff08;如 M…...

二叉数-965.单值二叉数-力扣(LeetCode)

一、题目解析 顾名思义&#xff0c;就是二叉树中所存储的值是相同&#xff0c;如果有不同则返回false 二、算法原理 对于二叉树的遍历&#xff0c;递归无疑是最便捷、最简单的方法&#xff0c;本题需要用到递归的思想。 采取前序遍历的方法&#xff0c;即根、左、右。 我们…...

redis集群和哨兵的区别

Redis Sentinel系统监控并确保主从数据库的正常运行&#xff0c;当主数据库故障时自动进行故障迁移。哨兵模式提供高可用性&#xff0c;客户端通过Sentinel获取主服务器地址&#xff0c;简化管理。Redis集群实现数据分布式存储&#xff0c;通过槽分区提高并发量&#xff0c;解决…...

[蓝桥杯]对局匹配

对局匹配 题目描述 小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分&#xff0c;代表他的围棋水平。 小明发现网站的自动对局系统在匹配对手时&#xff0c;只会将积分差恰好是 K 的两名用户匹配在一起。如果两人分差小于或大于 KK&#xff0c;…...

BBU 电源市场报告:深入剖析与未来展望​

在当今数字化时代&#xff0c;数据中心的稳定运行至关重要。BBU 电源作为保障数据中心设备在停电或电压下降期间临时电力供应的关键系统&#xff0c;其市场发展备受关注。本文将从市场规模、竞争格局、产品类型、应用领域等多个维度对 BBU 电源市场进行深入分析&#xff0c;并为…...

Redis 持久化机制详解:RDB 与 AOF 的原理、优缺点与最佳实践

目录 前言1. Redis 持久化机制概述2. RDB 持久化机制详解2.1 RDB 的工作原理2.2 RDB 的优点2.3 RDB 的缺点 3. AOF 持久化机制详解3.1 AOF 的工作原理3.2 AOF 的优点3.3 AOF 的缺点 4. RDB 与 AOF 的对比分析5. 持久化机制的组合使用与最佳实践6. 结语 前言 Redis 作为一款高性…...

Hadoop企业级高可用与自愈机制源码深度剖析

Hadoop企业级高可用与自愈机制源码深度剖析 前言 在大数据平台生产环境中&#xff0c;高可用&#xff08;HA&#xff09;与自动化自愈能力直接决定了数据安全与服务稳定性。本文结合源码与实战&#xff0c;深入剖析Hadoop生态中YARN高可用、HDFS自动扩容、故障自愈三大核心机…...

【Kotlin】简介变量类接口

【Kotlin】简介&变量&类&接口 【Kotlin】数字&字符串&数组&集合 【Kotlin】高阶函数&Lambda&内联函数 【Kotlin】表达式&关键字 文章目录 Kotlin_简介&变量&类&接口Kotlin的特性Kotlin优势创建Kotlin项目变量变量保存了指向对…...

Mybatis入门到精通

一&#xff1a;什么是Mybatis 二&#xff1a;Mybatis就是简化jdbc代码的 三&#xff1a;Mybatis的操作步骤 1&#xff1a;在数据库中创建一个表&#xff0c;并添加数据 我们这里就省略了 2&#xff1a;Mybatis通过maven来导入坐标&#xff08;jar包&#xff09; 3&#xff1a…...

Unity性能优化笔记

降低Draw Call 降低draw call&#xff08;unity里叫batches&#xff09;的方法有&#xff1a; 模型减少材质&#xff1b; 多模型共用材质&#xff1b; 烘焙灯光&#xff1b; 关闭阴影和雾&#xff1b; 遮挡剔除&#xff1b; 使用LOD&#xff1b; 模型减少材质 > 见…...

BERT vs Rasa 如何选择 Hugging Face 与 Rasa 的区别 模型和智能体的区别

我在之前的一篇文章中提到我的短期目标的问题&#xff0c;即想通过Hugging Face的BERT或Rasa搭建一个简单的意图识别模型&#xff0c;针对发票业务场景来展示其效果 [如&#xff1a;开发票、查询发票]。 开篇&#xff0c;有必要记录几个英文缩写或术语 &#xff08;如果喜欢&a…...

Excel 重复项标记,删除重复项时出现未响应的情况

目录 一、重复值标记&#xff1a; 二、删除重复值&#xff1a; 三、未响应问题 一、重复值标记&#xff1a; 方法1&#xff1a;开始 》条件格式 》突出显示单元格规则 》重复值 》设置颜色 》确定 PS&#xff1a;样式可自定义&#xff08;边框、字体、背景填充...&#xff0…...

CppCon 2015 学习:Beyond Sanitizers

Sanitizers&#xff0c;一类基于编译时插桩&#xff08;instrumentation&#xff09;的动态测试工具&#xff0c;用来检测程序运行时的各种错误。 Sanitizers 简介 基于编译时插桩&#xff1a;编译器在编译代码时自动插入检测代码。动态运行时检测&#xff1a;程序运行时实时…...

Mysql选择合适的字段创建索引

1. 考虑字段的选择性 选择性&#xff1a;字段的选择性是指字段中不重复值的比例。选择性越高&#xff08;即不重复值越多&#xff09;&#xff0c;索引的效率越高。 示例&#xff1a; 如果一个字段有100万行数据&#xff0c;但只有2个不重复值&#xff08;如性别字段&#xff…...

Python:操作 Excel 格式化

🔧Python 操作 Excel 格式化完整指南(openpyxl 与 xlsxwriter 双方案) 在数据处理和报表自动化中,Python 是一把利器,尤其是配合 Excel 文件的读写与格式化处理。本篇将详细介绍两大主流库: openpyxl:适合读取与修改现有 Excel 文件xlsxwriter:适合创建新文件并进行复…...

ant-design-vue select 下拉框不好用解决

将optionFilterProp设置为label和a-select-option的:label"item.name"自定义属性 <a-selectshowSearchallowClearoptionFilterProp"label"placeholder"请选择选项"style"width: 120px; margin-right: 16px"><a-select-optio…...

[Java 基础]创建人类这个类小练习

请根据如下的描述完成一个小练习&#xff1a; 定义一个名为 Human 的 Java 类在该类中定义至少三个描述人类特征的实例变量&#xff08;例如&#xff1a;姓名、年龄、身高&#xff09;为 Human 类定义一个构造方法&#xff0c;该构造方法能够接收所有实例变量作为参数&#xf…...