C语言实现随机发扑克牌

所属分类: 软件编程 / C 语言 阅读数: 89
收藏 0 赞 0 分享

本文实例为大家分享了C语言实现随机发扑克牌的具体代码,供大家参考,具体内容如下

算法如下:

1、将1-10作为方块、2-20作为梅花,3-30作为红桃,4-40作为黑桃,JQK以及大小王分别排序共54张存放在一维数组中。
3、3个人用一个二维数组来存放三人的牌。
2、主要分为打散(乱序),分配,显示三个操作

打散即洗牌:通过rand以及srand函数来获得,为了避免相同的序列,使用标准时间来作为序列种子。

void shuffle(int *cards, int lenth)
{
 int temp, i, index;
  
 time_t t;
 srand((unsigned int)(&t)); 
  
 for (i = 0; i < lenth - 1; i++) //保证每一次交换都是和剩下的数进行交换
 {
  index = rand() % (lenth - i) + i;

  if (index != i) 
  {
    temp = cards[i];
    cards[i] = cards[index];
    cards[index] = temp;
  }
 }
}

分配:将乱序的卡组分别依次排入一个二维数组中

void deal(int(*everycards)[18], int* cards)
{
 int i, j;
 
 for (i = 0; i < 3; i++)
 {
  for (j = 0; j < 18; j++)
  {
   everycards[i][j] = cards[i * 18 + j];
  }
 }
 }

显示:数字卡用迭代的方法显示,而JQK则用switch方法实现

void display(int(*everycards)[18], char *name1, char *name2, char *name3)
{
 int i, j;
 //方块、梅花、红桃、黑桃
 putchar('\n');
 printf("分配卡牌如下:\n");
 for (i = 0; i < 3; i++)
 {
 switch (i)
 {
 case 0: printf("%s手上的牌是: ", name1); break;
 case 1: printf("%s手上的牌是: ", name2); break;
 case 2: printf("%s手上的牌是: ", name3); break;
 }
 for (j = 0; j < 18; j++)
 {
 if (everycards[i][j] >= 1 && everycards[i][j] <= 10)
 {
 printf("方%d ", everycards[i][j]);
 }
 else if (everycards[i][j] >= 11 && everycards[i][j] <= 20)
 {
 printf("梅%d ", everycards[i][j] - 10);
 } 
 else if (everycards[i][j] >= 21 && everycards[i][j] <= 30)
 {
 printf("红%d ", everycards[i][j] - 20);
 }
 else if (everycards[i][j] >= 31 && everycards[i][j] <= 40)
 {
 printf("黑%d ", everycards[i][j] - 30);
 }
 else
 {
 switch (everycards[i][j])
 {
 case 41: printf("方J "); break;
 case 42: printf("方Q "); break;
 case 43: printf("方K "); break;
 case 44: printf("梅J "); break;
 case 45: printf("梅Q "); break;
 case 46: printf("梅K "); break;
 case 47: printf("红J "); break;
 case 48: printf("红Q "); break;
 case 49: printf("红K "); break;
 case 50: printf("黑J "); break;
 case 51: printf("黑Q "); break;
 case 52: printf("黑K "); break;
 case 53: printf("小王 "); break;
 case 54: printf("大王 "); break;
 }
 }
 }
 putchar('\n');
 putchar('\n');
 }
}

具体实现如下

主函数下方所示(由于是vs2019所以scanf用的是微软自带的scanf_s):

int main(void)
{
 char name1[MAX], name2[MAX], name3[MAX];
 int cards[54], everycards[3][18], lenth, i;
 char YorN;
 //初始化扑克牌
 for (int count1 = 0; count1 < 54; count1++)
 {
 cards[count1] = count1 + 1;
 }
 lenth = sizeof(cards) / sizeof(cards[0]);
 
 printf("请输入1号玩家的名字:");
 scanf_s("%s", name1, MAX);
 int b1 = getchar();
 printf("请输入2号玩家的名字:");
 scanf_s("%s", name2, MAX);
 int b2 = getchar(); 
 printf("请输入3号玩家的名字:");
 scanf_s("%s", name3, MAX);
 int b3 = getchar();
 putchar('\n');
 printf("方块 = 方,梅花 = 梅,红桃 = 红, 黑桃 = 黑\n");
 //先做一次洗牌
 shuffle(cards, lenth);
 deal(everycards, cards);
 display(everycards, name1, name2, name3);
 //寻问是否进行再次洗牌
 while (1)
 {
 printf("\n请选择是否重新洗牌(Y/N):");
 scanf_s("%c", &YorN);
 int b4 = getchar();
 //
 if (YorN == 'Y')
 {
 shuffle(cards, lenth);
 deal(everycards, cards);
 display(everycards, name1, name2, name3);
 }
 else if (YorN == 'N')
 {
 break;
 }
 }

 return 0;
}

学生党,初学习编程,第一次发博客,望各位大佬指正错误和不足。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

利用C语言来求最大连续子序列乘积的方法

这篇文章主要介绍了利用C语言来求最大连续子序列乘积的方法,基本的思路以外文中还附有相关ACM题目,需要的朋友可以参考下
收藏 0 赞 0 分享

用C语言判断一个二叉树是否为另一个的子结构

这篇文章主要介绍了用C语言判断一个二叉树是否为另一个的子结构,是数据结构学习当中的基础知识,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言实现的阶乘,排列和组合实例

这篇文章主要介绍了C语言实现的阶乘,排列和组合的方法,涉及C语言数学运算的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言查找数组里数字重复次数的方法

这篇文章主要介绍了C语言查找数组里数字重复次数的方法,涉及C语言针对数组的遍历与判断技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言简单实现计算字符个数的方法

这篇文章主要介绍了C语言简单实现计算字符个数的方法,涉及C语言针对字符串的简单遍历与判定技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

c实现linux下的数据库备份

本文给大家简单介绍下c实现linux下的数据库备份的方法和具体的源码,十分的实用,有需要的小伙伴可以参考下。
收藏 0 赞 0 分享

C++获得文件状态信息的方法

这篇文章主要介绍了C++获得文件状态信息的方法,包括文件状态信息、文件所在磁盘盘符、文件创建时间、访问时间及修改日期等,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言按关键字搜索文件夹中文件的方法

这篇文章主要介绍了C语言按关键字搜索文件夹中文件的方法,涉及C语言文件操作及字符串查找的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言之字符串模糊查询方法的实现

本篇文章主要为大家介绍字符串模糊查询的C语言程序编写方法,有需要的朋友可以参考下
收藏 0 赞 0 分享

C语言实现BMP转换JPG的方法

这篇文章主要介绍了C语言实现BMP转换JPG的方法,涉及C#图片格式转换的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多