结构体人工模拟洗牌

这个博客介绍了一种使用C++实现的人工模拟洗牌算法,通过定义结构体来存储扑克牌的面值和花色,并利用随机数进行洗牌操作。程序详细解释了如何处理牌的面值(包括将1、11、12、13转换为A、J、Q、K)和花色,并展示了如何遍历并输出洗牌后的结果。
摘要由CSDN通过智能技术生成
//******************************结构体人工模拟洗牌*************************************// 

#include<stdio.h>

#include<iostream>

#include<cstring>

#include<cstdlib>

#include<ctime>

//#define A 1

//#define J 11

//#define Q 12

//#define K 13

using namespace std;

 

//*********************************************************//

typedef enum

{

       A=1,J=11,Q=12,K=13

}mian_zhi;

 

struct card

{

       int num;  //牌的面值

 

       char kind;//牌的花色

};

 

struct card deck[52];//定义结构体数组

 

void swap(struct card*,struct card*);//声明

 

//*******************模拟人工洗牌过程********************//

 

void moni(struct card d[])//模拟人工洗牌过程

{

       int i,j;

       srand((unsigned)time(NULL));

       for(i=1;i<52;i++)                 //注意i=1开始,防止出现的牌中有0,不符合扑克牌

       {

              j=rand()%52;

              swap(&d[i],&d[j]);//用交换实现洗牌

       }

}

 

//*********************交换实现洗牌*************************//

 

void swap(struct card *p1,struct card *p2)

{

       struct card temp;

       temp = *p1;

       *p1  = *p2;

       *p2  = temp;

}

 

//************************************************************//

 

void main(void)

{

       int i;

       for(i=0;i<=51;i++)//遍历52张牌

       {

              switch(i/13)//判断4种花色

              {

              case 0://0~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值