C语言实现自动发牌程序

 更新时间:2020年04月22日 15:18:21   作者:陈子剑  
这篇文章主要为大家详细介绍了C语言实现自动发牌程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C语言自动发牌程序,供大家参考,具体内容如下

一副扑克有52张牌,打桥牌时应将牌分给4个人。请设计一个程序完成自动发牌的工作。要求:黑桃用S (Spaces)表示,红桃用H (Hearts)表示,方块用D (Diamonds)表示,梅花用C (Clubs)表示。

分析:

要设置数组表现扑克牌
要设置数组表现玩家
要给扑克牌做特定标识,得到结果后玩家要知道自己手中黑桃有哪些、方块有哪些

初步想法:

设置4个字符数组保存4种梅花牌,设置4个字符数组表示4名玩家分配到的牌
每张牌随机发给4名玩家,当玩家的持牌数达到13,不再分配给该名玩家牌

代码展示:

void mycode_13()
{
 srand(unsigned(time(NULL)));
 /*全部牌*/
 char S[13] = { '2', '3', '4', '5', '6', '7', '8', '9', 'T', 'J', 'Q', 'K', 'A' };
 char H[13] = { '2', '3', '4', '5', '6', '7', '8', '9', 'T', 'J', 'Q', 'K', 'A' };
 char D[13] = { '2', '3', '4', '5', '6', '7', '8', '9', 'T', 'J', 'Q', 'K', 'A' };
 char C[13] = { '2', '3', '4', '5', '6', '7', '8', '9', 'T', 'J', 'Q', 'K', 'A' };

 /*4个玩家*/
 char player1[13], player2[13], player3[13], player4[13];
 int p1 = 0, p2 = 0, p3 = 0, p4 = 0;

 distribution(S, player1, player2, player3, player4, &p1, &p2, &p3, &p4);
 distribution(H, player1, player2, player3, player4, &p1, &p2, &p3, &p4);
 distribution(D, player1, player2, player3, player4, &p1, &p2, &p3, &p4);
 distribution(C, player1, player2, player3, player4, &p1, &p2, &p3, &p4);

 puts("运行结束");

 for (int i = 0; i < 13; i++)
 printf("%c ", player1[i]);
 putchar('\n');
 for (int i = 0; i < 13; i++)
 printf("%c ", player2[i]);
 putchar('\n');
 for (int i = 0; i < 13; i++)
 printf("%c ", player3[i]);
 putchar('\n');
 for (int i = 0; i < 13; i++)
 printf("%c ", player4[i]);
}

void distribution(char * S_H_D_C, char * player1, char * player2, char * player3, char * player4, int *p1, int *p2, int *p3, int *p4)
{
 static int h = 1;
 int r;
 int a = *p1, b = *p2, c = *p3, d = *p4;

 for (int i = 0; i < 13; i++)
 {
 r = (rand() % 4) + 1;
 while ((r == 1 && (*p1) == 13) || (r == 2 && (*p2) == 13) || (r == 3 && (*p3) == 13) || (r == 4 && (*p4) == 13))
  r = (rand() % 4) + 1;
 
 switch (r)
 {
 case 1:
  player1[(*p1)++] = S_H_D_C[i];
  break;
 case 2:
  player2[(*p2)++] = S_H_D_C[i];
  break;
 case 3:
  player3[(*p3)++] = S_H_D_C[i];
  break;
 case 4:
  player4[(*p4)++] = S_H_D_C[i];
  break;
 default:
  break;
 }
 }
 
 switch (h++)
 {
 case 1:
  printf("黑桃:\n");
  break;
 case 2:
  printf("红桃:\n");
  break;
 case 3:
  printf("方块:\n");
  break;
 case 4:
  printf("梅花:\n");
  break;
 }
 
 printf("Player1:");
 for (int i = a; i < (*p1); i++)
  printf("%c ", player1[i]);

 putchar('\n');
 
 printf("Player2:");
 for (int i = b; i < (*p2); i++)
  printf("%c ", player2[i]);
 
 putchar('\n');
 printf("Player3:");
 for (int i = c; i < (*p3); i++)
  printf("%c ", player3[i]);
 
 putchar('\n');
 
 printf("Player4:");
 for (int i = d; i < (*p4); i++)
  printf("%c ", player4[i]);

 putchar('\n');
}

以下代码保证了当某个人得到13张牌后不在得牌

r = (rand() % 4) + 1;
 while ((r == 1 && (*p1) == 13) || (r == 2 && (*p2) == 13) || (r == 3 && (*p3) == 13) || (r == 4 && (*p4) == 13))
  r = (rand() % 4) + 1;

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

相关文章

  • 深入了解C++智能指针的使用

    深入了解C++智能指针的使用

    智能指针的本质就是使用一个对象来接管一段开辟的空间,在该对象在销毁的时候,自动调用析构函数来释放这段内存。本文就来和大家详细聊聊智能指针的使用,需要的可以参考一下
    2022-10-10
  • C++原地删除有序数组重复项的N种方法

    C++原地删除有序数组重复项的N种方法

    给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用O(1)额外空间的条件下完成,故本文介绍了C++原地删除有序数组重复项的N种方法,需要的朋友可以参考下
    2025-03-03
  • OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    这篇文章主要给大家介绍了关于OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • C语言实现数字炸弹小游戏

    C语言实现数字炸弹小游戏

    这篇文章主要为大家详细介绍了C语言实现数字炸弹小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • C++ 中类(class)和结构体(struct)的区别

    C++ 中类(class)和结构体(struct)的区别

    类和结构体经常被用来定义复杂的数据结构,但两者之间既有区别又能很好地结合使用,本文主要介绍了C++ 中类(class)和结构体(struct)的区别,具有一定的参考价值,感兴趣的可以了解一下
    2025-04-04
  • Visual Studio 2022卡死分析

    Visual Studio 2022卡死分析

    本文主要介绍了Visual Studio 2022卡死分析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • C语言超全面覆盖操作符知识点

    C语言超全面覆盖操作符知识点

    C 语言提供了丰富的操作符,有:算术操作符,移位操作符,位操作符,赋值操作符,单目操作符,关系操作符,逻辑操作符,条件操作符等。让我们通读本篇来详细了解吧
    2022-06-06
  • C++实现LeetCode(80.有序数组中去除重复项之二)

    C++实现LeetCode(80.有序数组中去除重复项之二)

    这篇文章主要介绍了C++实现LeetCode(80.有序数组中去除重复项之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 扩展KMP算法(Extend KMP)

    扩展KMP算法(Extend KMP)

    我们这里说的KMP不是拿来放电影的(虽然我很喜欢这个软件),而是一种算法。KMP算法是拿来处理字符串匹配的。今天我们谈到的是对KMP算法的拓展
    2014-08-08
  • C语言实现字符串拼接和拷贝

    C语言实现字符串拼接和拷贝

    这篇文章主要为大家详细介绍了C语言实现字符串拼接和拷贝,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08

最新评论