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

综合案例:斗地主

综合案例:斗地主

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]);}
}

运行效果:

在这里插入图片描述

http://www.lqws.cn/news/135487.html

相关文章:

  • 【算法训练营Day06】哈希表part2
  • 基于单片机的FFT的频谱分析仪设计
  • css实现圆环展示百分比,根据值动态展示所占比例
  • Haystack:AI与IoT领域的全能开源框架
  • 【conda配置深度学习环境】
  • PhpStorm设置中文
  • Monorepo架构: 项目管理工具介绍、需求分析与技术选型
  • 西肯麦远程数据通讯架构说明
  • 实战解析MCP-使用本地的Qwen-2.5模型-AI协议的未来?
  • 让AI看见世界:MCP协议与服务器的工作原理
  • 【C/C++】入门grpc的idl
  • Webpack搭建本地服务器
  • PyTorch——优化器(9)
  • Web开发主流前后端框架总结
  • [特殊字符] Spring Boot底层原理深度解析与高级面试题精析
  • PDF处理控件Aspose.PDF教程:在 C# 中更改 PDF 页面大小
  • (LeetCode 每日一题)3403. 从盒子中找出字典序最大的字符串 I (贪心+枚举)
  • [Java 基础]面向对象-封装
  • STM32上部署AI的两个实用软件——Nanoedge AI Studio和STM32Cube AI
  • C++11 中 auto 和 decltype 的深入解析
  • 服务器中僵尸网络攻击是指什么?
  • 前端css外边距塌陷(Margin Collapse)现象原因和解决方法
  • 编程技能:格式化打印04,sprintf
  • 虚拟斯德哥尔摩症候群:用户为何为缺陷AI辩护?
  • 在CSDN发布AWS Proton解决方案:实现云原生应用的标准化部署
  • AWS DocumentDB vs MongoDB:数据库的技术抉择
  • AWS 成本异常检测IAM策略
  • 【知识点】第6章:组合数据类型
  • idea相关功能
  • sylar--线程模块