C语言实现随机发扑克牌

本文实例为大家分享了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;
}

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

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

(0)

相关推荐

  • C语言实现随机发牌

    本文实例为大家分享了C语言实现随机发牌的具体代码,供大家参考,具体内容如下 #include "stdafx.h" #include<time.h> #include<stdlib.h> int card[54];//保存每张牌的数字符号 bool flag[54];//标记数组 false 代表这个单元编号的牌没抽过 void show1(); void mix1(); int main() { srand(time(NULL)); mix1(); show1

  • C语言编写洗牌发牌程序

    用C语言编写洗牌发牌程序,供大家参考,具体内容如下 题目 现在只有一套扑克牌中52张副牌(无大王小王),包含了4种花色的牌 现在打乱顺序后分给甲乙丙丁四人 全部分配完毕后,输出甲乙丙丁四人所获得的扑克大小及花色 再经过排序,将甲乙丙丁四人的牌按由大到小顺序输出到屏幕上 要素提取 略 补充 牌面上的数字/字母由小到大为: 3 4 5 6 7 8 9 10 J Q K A 2 牌面上的花色由小到大为: 方块 梅花 红桃 黑桃 思路 略 可能出现的问题 略 代码 #include<stdio.h>

  • C语言实现纸牌计算24点小游戏

    利用系统时间设定随机种子生成4个随机数,并对4个数字之间的运算次序以及运算符号进行枚举,从而计算判断是否能得出24,以达到程序目的.程序主要功能已完成,目前还有部分细节未处理,待完成ing...对于代码中的错误,恳请批评指正. 游戏描述: A-10:分别代表数字 1-10. J,Q,K:均代表数字1. 考虑到部分地方的规则,J,Q,K 也可以当成10 ,或者直接代表本身所代表的数字,即11.12.13来运算. 使用加减乘除,能得出24者为赢,存在无解情况. 游戏开始得分为1000分,每一秒钟减少

  • C语言实现扑克牌计算24点

    题目描述: 一副扑克牌的每张牌表示一个数(J.Q.K分别表示11.12.13,两个司令都表示6).任取4张牌,即得到4个1~13的数,请添加运算符(规定为加+ 减- 乘* 除/ 四种)使之成为一个运算式.每个数只能参与一次运算,4个数顺序可以任意组合,4个运算符任意取3个且可以重复取.运算遵从一定优先级别,可加括号控制,最终使运算结果为24.请输出一种解决方案的表达式,用括号表示运算优先.如果没有一种解决方案,则输出-1表示无解. 输入格式说明: 输入在一行中给出4个整数,每个整数取值在[1,

  • C语言实现纸牌24点小游戏

    本文实例为大家分享了C语言纸牌24点小游戏的具体实现代码,供大家参考,具体内容如下 此程序参考C语言实现经典24点纸牌益智游戏,并做出一些改进. 一.题目要求: 24点游戏规则: 从扑克中每次取出4张牌.使用加减乘除,第一个能得出24者为赢.(其中,J代表11,Q代表12,K代表13,A代表1),按照要求编程解决24点游戏. 基本要求: 随机生成4个代表扑克牌牌面的数字字母,程序自动列出所有可能算出24的表达式,用擅长的语言(C/C++/Java或其他均可)实现程序解决问题. 1.程序风格良好(

  • C语言实现简易扑克牌游戏

    将一副扑克牌平均分成两份,每人拿一份.a先拿出手中的第一张扑克牌放在桌上,然后b也拿出手中的第一张扑克牌,并放在a刚打出的扑克牌的上面,就像这样两人交替出牌.出牌时,如果某人打出的牌与桌上某张牌的牌面相同,即可将两张相同的牌及其中间所夹的牌全部取走,并依次放到自己手中牌的末尾.当任意一人手中的牌全部出完时,游戏结束,对手获胜. 以下是代码的实现: #define _crt_secure_no_deprecate #include<stdio.h> #include<stdlib.h>

  • 使用C语言求解扑克牌的顺子及n个骰子的点数问题

    扑克牌的顺子     问题描述:从扑克牌中随机抽5张牌,判断是不是一个顺子,即这5张牌是不是连续的.2-10为数字本身,A为1,J为11,Q为12,K为13,而大小王可以看成任意数字.          思路:可以将这5张牌排个序,然后统计出0的个数以及非0数字之间的间隔数,如果出现重复的非0数字,那么不是顺子.如果间隔数小于等于0的个数,那么是顺子.暂时未想到更好的办法.          参考代码: //函数功能 : 从扑克牌中随机抽5张牌,判断是不是一个顺子 //函数参数 : pCards

  • C语言实现自动发牌程序

    C语言自动发牌程序,供大家参考,具体内容如下 一副扑克有52张牌,打桥牌时应将牌分给4个人.请设计一个程序完成自动发牌的工作.要求:黑桃用S (Spaces)表示,红桃用H (Hearts)表示,方块用D (Diamonds)表示,梅花用C (Clubs)表示. 分析: 要设置数组表现扑克牌 要设置数组表现玩家 要给扑克牌做特定标识,得到结果后玩家要知道自己手中黑桃有哪些.方块有哪些 初步想法: 设置4个字符数组保存4种梅花牌,设置4个字符数组表示4名玩家分配到的牌 每张牌随机发给4名玩家,当玩

  • C语言实现经典24点纸牌益智游戏

    一.常见游戏规则 从扑克中每次取出4张牌.使用加减乘除,第一个能得出24者为赢.(其中,J代表11,Q代表12,K代表13,A代表1),按照要求编程解决24点游戏. 基本要求: 随机生成4个代表扑克牌牌面的数字字母,程序自动列出所有可能算出24的表达式,用擅长的语言(C/C++/Java或其他均可)实现程序解决问题. 1.程序风格良好(使用自定义注释模板) 2.列出表达式无重复. 二.具体代码 #include<iostream> #include<stdlib.h> #inclu

  • C语言实现洗牌发牌小程序

    本文实例为大家分享了C语言实现洗牌发牌小程序的具体代码,供大家参考,具体内容如下 构建一副扑克牌,并实现洗牌发牌. 代码 #include <stdio.h> #include <time.h> #include <stdlib.h> #define NUM 10000 //洗牌混乱度 char color[7][7] = {"空白","红桃","黑桃","草花","方片"

随机推荐