C++实现洗牌发牌排序功能的示例代码实现洗牌发牌排序功能的示例代码
在内存中模拟出一副牌,然后模拟洗牌,发牌等动作。
流程是这样的:构建一副牌保存到一个数组中—洗牌—创建玩家—向玩家发牌–输出每个玩家的牌。
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
//定义扑克的花色
enum Suit{
heart,
spade,
diamond,
club,
joker1,
joker2
};
//一副牌的数量
#define CARD_COUNT 54
//定义扑克
typedef struct Card{
int value;//牌的点数从1开始
enum Suit suit;//花色
}Card;
//定义玩家
typedef struct Player{
char name[64];//玩家的名字
Card ** cards;//玩家分到的牌。每项是一个指针,指向原始一副牌数组中的一项,这样可以节省空间
int cardsCount;//玩家分到的牌的数量
}Player;
//分牌完成后调用的函数的类型
typedef int (*COMPARE)(Card* ,Card*);
//函数声明们
char* getCardName(const Card*);
Card** shuffle(const Card*);
void dispatchCards(Player** ,int ,const Card** );
void sort(Card**,int,COMPARE);
int compare1(Card* ,Card*);
int compare2(Card* ,Card*);
void initOnePack();
//原始一副牌所在的数组
Card pokers[CARD_COUNT];
//入口函数
int main(void)
{
//初始化一副牌
initOnePack();
//洗牌,shuffledPokers保存洗后的牌们
Card** shuffledPokers = shuffle(pokers);
//构建三个玩家
Player player1;
strcpy(player1.name,"隔壁老王");
player1.cards=NULL;
player1.cardsCount=0;
Player player2;
strcpy(player2.name,"小明");
player2.cards=NULL;
player2.cardsCount=0;
Player player3;
strcpy(player3.name,"田中龟孙");
player3.cards=NULL;
player3.cardsCount=0;
//把三放到一个数组中,以传入发牌函数中
Player* players[]={&player1,&player2,&player3};
//发牌
dispatchCards(players,sizeof(players)/sizeof(Player*),shuffledPokers);
//洗后的牌用完了,释放之
free(shuffledPokers);
int i;
//打印出每个玩家手中的牌
for(i=0;i<sizeof(players)/sizeof(Player*);i++){
//先打印玩家的名字