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

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

本文实例为大家分享了C语言实现洗牌发牌小程序的具体代码,供大家参考,具体内容如下

构建一副扑克牌,并实现洗牌发牌。

代码

#include <stdio.h>
#include <time.h>
#include <stdlib.h>
 
#define NUM 10000 //洗牌混乱度
 
char color[7][7] = {"空白","红桃","黑桃","草花","方片","小王","大王"}; // 1:红桃 2:黑桃 3:草花 4:方片 5:小王 6:大王
char number[]={"0A234567890JQK"}; // 0:不存内容 1:A 2:2 3:3 4:4 5:5 6:6 7:7 8:8 9:9 10:10 11:J 12:Q 13:K
 
//构建扑克
struct card{
  unsigned int number;
  unsigned int color;
};
 
unsigned int NUM_card=53; //剩余未发的牌数(发牌时用的变量)
 
struct card card[54]; //创建保存一副牌的结构体
 
 
//构建一副牌(有序)
void creat_pair_card()
{
  int num=1;
  int col=1;
  int i=0;
  for(num=1;num<=15;num++)
  {
    //生成大小王
    if(num>=14)
    {
      card[i].number=num;
      card[i].color=col++;
      i++;
    }
    else
    {
      //生成普通牌
      for(col=1;col<=4;col++)
      {
        card[i].number=num;
        card[i].color=col;
        i++;
      }
    }
  }
}
 
//显示一副牌
void print_card()
{
  int i;  
  int num,col; //点数与花色对应数组下标
  for(i=0;i<54;i++)
  {
    col=card[i].color;
    num=card[i].number;
    if(col>=5)
    {
      printf("%s\t",color[col]);
    }
    else
    {
      if(num==10)
      {
        printf("%s:",color[col]);
        printf("10\t");
      }
      else
      {
        printf("%s:",color[col]);
        printf("%c\t",number[num]);
      }
    } 
  }
  printf("\n");
}
 
 
//洗牌
void wash_card()
{
  int i;
  int ch1,ch2;
  srand((unsigned)time(NULL));
  for(i=0;i<NUM;i++) //循环次数越大越乱
  {
    
    
    ch1=rand()%100; //2147483647 取最后两位0-99
    ch2=rand()%100;
    
 
    if(ch1>53)
    {
      ch1=100-ch1; //随机数大于53则减小
    }
 
    if(ch2>53)
    {
      ch2=100-ch2;
    }
 
    if(ch1 == ch2)
    {
      continue;
    }
    //两个随机牌交换
    struct card tmp=card[ch1];
    card[ch1]=card[ch2];
    card[ch2]=tmp;
  }
}
 
//发牌
void send_card(struct card hand[],int num)
{
  if(NUM_card<num)
  {
    printf("数量不足\n");
    return;
  }
  int i;
  for(i=0;i<num;i++)
  {
    hand[i]=card[NUM_card-i];
  }
  NUM_card=NUM_card-num;
}
 
 
//显示手牌
void print_hand_card(struct card hand[],int num)
{
  int i;
  int point,col;
  for(i=0;i<num;i++)
  {
    col=hand[i].color;
    point=hand[i].number;
    if(col>=5)
    {
      printf("%s ",color[col]);
    }
    else
    {
      if(point==10)
      {
        printf("%s:",color[col]);
        printf("10 ");
      }
      else
      {
        printf("%s:",color[col]);
        printf("%c ",number[point]);
      }
    } 
  }
  printf("\n");
}
 
 
int main(void)
{
 
  creat_pair_card(); //创建一副牌 有序
  wash_card();//洗牌
  print_card();//打印
 
  struct card hand1[17]; //创建两个结构体保存手牌17张
  struct card hand2[17];
  send_card(hand1,17); //发牌
  send_card(hand2,17);
  printf("手牌A: ");
  print_hand_card(hand1,17);
  printf("\n");
  printf("手牌B: ");
  print_hand_card(hand2,17);
  printf("\n");
}

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

相关文章

  • 基于C++实现去除字符串头尾指定字符功能

    基于C++实现去除字符串头尾指定字符功能

    编程时我们经常需要对字符串进行操作,其中有一项操作就是去除字符串的头(尾)指定的字符,比如空格。本文为大家详细介绍了如何利用C++实现这一效果,需要的可以参考一下
    2022-04-04
  • C++实现单例模式的自动释放

    C++实现单例模式的自动释放

    这篇文章主要为大家详细介绍了C++实现单例模式的自动释放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • 基于C++实现柏林噪声算法(Perlin Noise)

    基于C++实现柏林噪声算法(Perlin Noise)

    Perlin噪声(Perlin noise,又称为柏林噪声)指由Ken Perlin发明的自然噪声生成算法,具有在函数上的连续性,并可在多次调用时给出一致的数值。本文将用C++实现柏林噪声算法,感兴趣的可以了解一下
    2023-03-03
  • C++多线程传参的实现方法

    C++多线程传参的实现方法

    本文主要介绍了C++多线程传参的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • c++标准库读写ini文件的实现示例

    c++标准库读写ini文件的实现示例

    本文介绍了一个完整的INI文件类的实现,包含读取和写入操作,通过IniFile.h头文件和IniFile.cpp实现文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-10-10
  • C++中的内存分区介绍

    C++中的内存分区介绍

    这篇文章主要介绍了C++中的内存分区介绍,C++的内存划分为栈区、堆区、全局区/静态区、字符串常量和代码区,本文分别对他们一一说明,需要的朋友可以参考下
    2015-07-07
  • C语言中字符串常用函数strcat与strcpy的用法介绍

    C语言中字符串常用函数strcat与strcpy的用法介绍

    以下是对C语言中字符串常用函数strcat与strcpy的使用方法进行了详细的分析介绍,需要的朋友可以参考下
    2013-07-07
  • C++基于reactor的服务器百万并发实现与讲解

    C++基于reactor的服务器百万并发实现与讲解

    这篇文章主要介绍了C++基于reactor的服务器百万并发实现与讲解,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • C语言之平衡二叉树详解

    C语言之平衡二叉树详解

    平衡二叉树是具有平衡属性的有序二叉树,本文主要介绍了C语言中的平衡二叉树,具有一定的参考价值,需要的小伙伴可以参考阅读
    2023-04-04
  • C++数据结构与算法之判断一个链表是否为回文结构的方法

    C++数据结构与算法之判断一个链表是否为回文结构的方法

    这篇文章主要介绍了C++数据结构与算法之判断一个链表是否为回文结构的方法,结合实例形式分析了回文结构并结合实例给出了C++判断回文的操作技巧,需要的朋友可以参考下
    2017-05-05

最新评论