当前位置: 首页 > 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]);}
}

运行效果:

在这里插入图片描述

相关文章:

  • IDEA中微服务指定端口启动
  • Rust 控制流
  • 深度学习之路——CNN卷积神经网络详解
  • Unity性能优化笔记
  • C++——智能指针 weak_ptr
  • 正则表达式检测文件类型是否为视频或图片
  • Linux-文件管理及归档压缩
  • Go语言爬虫系列教程4:使用正则表达式解析HTML内容
  • OPENCV的AT函数
  • 25_05_29docker
  • Windows系统工具:WinToolsPlus 之 SQL Server 日志清理
  • 数据库表中「不是 null」的含义
  • ArcGIS计算多个栅格数据的平均栅格
  • IEC 61347-1:2015 灯控制装置安全标准详解
  • 打卡第36天:模型可视化以及推理
  • React Native开发鸿蒙运动健康类应用的项目实践记录
  • 破解HTTP无状态:基于Java的Session与Cookie协同工作指南
  • 一个完整的时间序列异常检测系统,使用Flask作为后端框架,实现了AE(自编码器)、TimesNet和LSTM三种模型,并提供可视化展示
  • 八:操作系统设备管理之I/O 软件层次结构
  • 微软的新系统Windows12未来有哪些新特性
  • 用土豆做美食的视频网站/网站设计制作在哪能看
  • 美国人建设网站/搜狗引擎
  • wordpress成品网站yunbuluo/唐山seo排名优化
  • 东丽天津网站建设/ciliba磁力搜索引擎
  • WordPress网站根目录有哪些/网推怎么做
  • 做网站资源知乎/百度一下app下载安装