笔者在大学二年级期间,做过的一次C++程序设计:扑克牌的洗牌发牌游戏。具体内容是:除去大王和小王,将52张扑克牌洗牌,并发出5张牌。然后判断这5张牌中有几张相同大小的牌,是否是一条链,有几个同花等。

  笔者在学习他人设计的基础上,完成了自己的程序设计。这里将源程序分享给大家。

[1] 文件“card.h”

 #ifndef CARD_H
#define CARD_H
#include<string>
using namespace std; class Card
{
public:
static const int totalFaces=;
static const int totalSuits=; Card(int,int);
int getFace();
int getSuit();
string toString(); private:
int face,suit;
static const string faceNames[totalFaces];
static const string suitNames[totalSuits]; };
#endif // CARD_H

[2] 文件“card.cpp”

 #include"card.h"

 Card::Card(int faceNumber,int suitNumber)
{
face=faceNumber;
suit=suitNumber;
} string Card::toString()
{
return faceNames[face]+" of "+suitNames[suit];
} int Card::getFace() {return face;}
int Card::getSuit() {return suit;} const string Card::faceNames[totalFaces]=
{"A","","","","","","","","","","J","Q","K"}; const string Card::suitNames[totalSuits]=
{"heart","diamond","club","spade"};

[3] 文件“deckofcards.h”

 #ifndef DECKOFCARDS_H
#define DECKOFCARDS_H
#include<vector>
#include"card.h"
using namespace std; class DeckOfCards
{
public:
static const int fiveCards=;
static const int allCards=;
DeckOfCards();
void shuffle();
Card dealCard(int); void sortCards();
int duiziCards(int* sortFaces);
//bool moreCards(); private:
vector<Card> deck;
int currentCard; };
#endif // DECKOFCARDS_H

[4] 文件“deckofcards.cpp”

 #include"deckofcards.h"
#include<cstdlib>
#include<ctime> DeckOfCards::DeckOfCards()
{
//currentCard=0; for(int i=;i<allCards;i++)
{
Card card(i%Card::totalFaces,i/Card::totalFaces);
deck.push_back(card);
}
} void DeckOfCards::shuffle()
{
srand(time()); int swapRandom[allCards]; for(int i=;i<allCards;i++)
swapRandom[i]=int(rand())%allCards; for(int i=;i<allCards;i++)
{
Card swapCard(,);
swapCard=deck[i];
deck[i]=deck[swapRandom[i]];
deck[swapRandom[i]]=swapCard;
} } Card DeckOfCards::dealCard(int how_many)
{
for(int i=;i<how_many;i++)
{
cout <<deck[i].toString() <<endl;
if((i+)%==) cout <<endl;
}
} void DeckOfCards::sortCards()
{
int sortFaces[fiveCards];
int sortSuits[fiveCards];
for(int i=;i<fiveCards;i++)
{
sortFaces[i]=deck[i].getFace();
sortSuits[i]=deck[i].getSuit();
} for(int i=fiveCards-;i>=;i--)
for(int j=;j<=i-;j++)
if(sortFaces[j]>sortFaces[j+])
{
int t;
t=sortFaces[j];
sortFaces[j]=sortFaces[j+];
sortFaces[j+]=t;
} if((sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[])||
(sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[]))
cout <<"There are 4 same cards." <<endl; else if((sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[])||
(sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[])||
(sortFaces[]==sortFaces[]&&sortFaces[]==sortFaces[]))
cout <<"There are 3 same cards." <<endl; else if(int i=duiziCards(sortFaces))
cout <<"There are " <<i <<" pairs." <<endl; else
cout <<"There is no same cards." <<endl; if(sortFaces[]+==sortFaces[]&&sortFaces[]+==sortFaces[]&&
sortFaces[]+==sortFaces[]&&sortFaces[]+==sortFaces[])
cout <<"The five cards is a straight." <<endl;
else
cout <<"The five cards is not a straight." <<endl; if(sortSuits[]==sortSuits[]&&sortSuits[]==sortSuits[]&&
sortSuits[]==sortSuits[]&&sortSuits[]==sortSuits[])
cout <<"The five cards have same flower." <<endl;
else
cout <<"The five cards have different flower." <<endl; } int DeckOfCards::duiziCards(int* sortFaces)
{
int duiziNum=; for(int i=;i<fiveCards-;i++)
if(sortFaces[i]==sortFaces[i+]) duiziNum++; return duiziNum;
}

[5] main函数文件“main_FiveCards.cpp”

 #include<iostream>
#include"card.cpp"
#include"deckofcards.cpp"
using namespace std; int main()
{
DeckOfCards aDeck; cout <<"Deal all cards before shuffle." <<endl;
aDeck.dealCard(aDeck.allCards); aDeck.shuffle(); cout <<"Deal five cards after shuffle." <<endl;
aDeck.dealCard(aDeck.fiveCards); cout <<"\nThe result after sorting." <<endl;
aDeck.sortCards(); return ;
}

  将5个文件放在同一目录下,对文件“main_FiveCards.cpp”编译运行即可。以下是在CodeBlocks中的运行结果:

  

注:如有疑问或者高见,欢迎各位读者与笔者交流,以期共同学习进步。

C++分享笔记:扑克牌的洗牌发牌游戏设计的更多相关文章

  1. java斗地主扑克 扑克牌 洗牌 发牌 Collection 集合练习

    package com.swift.poker; import java.util.ArrayList; import java.util.Collections; /*训练考核知识点:Collect ...

  2. 实现斗地主纸牌游戏---洗牌 发牌 看底牌的具体功能------Map集合存储方法 遍历的应用

    该Demo只是斗地主的游戏的一部分,实现的斗地主的组合牌  洗牌  发牌 看牌的功能,主要应用Map集合进行练习 package cn.lijun import java.util.ArrayList ...

  3. Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)

    规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java ...

  4. JAVA程序设计(11)-----面对对象0基础设计 麻将 创建麻将牌 然后洗牌 发牌~ 恩 就这样

    zzzzZZZZ 1.開始还想贴图的 实在太懒了-- 这是一张麻将 package com.lovo; import java.awt.Graphics; import java.awt.Image; ...

  5. java——斗地主小游戏之洗牌发牌

    遇到的问题: 1.int和Integer的区别? 1)Integer是int的包装类,int则是java的一种基本数据类型 . 2)Integer变量必须实例化后才能使用,而int变量不需要 . 3) ...

  6. 算法笔记_128:完美洗牌算法(Java)

    目录 1 问题描述 2 解决方案 2.1位置置换算法 2.2 走环算法   1 问题描述 有一个长度为2n的数组{a1,a2,a3,...,an,b1,b2,b3,...,bn},希望排序后变成{a1 ...

  7. java 模拟斗地主发牌洗牌

    一 模拟斗地主洗牌发牌 1.案例需求 按照斗地主的规则,完成洗牌发牌的动作. 具体规则: 1. 组装54张扑克牌 2. 将54张牌顺序打乱 3. 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张 ...

  8. java集合--模拟斗地主发牌洗牌

    import java.util.*; /** * @Date: 2020/6/17 19:53 */public class Test04 { public static void main(Str ...

  9. Java基础知识强化之集合框架笔记71:模拟斗地主洗牌和发牌并对牌进行排序的案例

    1. 模拟斗地主洗牌和发牌并对牌进行排序的原理图解: 2. 代码实现: 思路: • 创建一个HashMap集合 • 创建一个ArrayList集合 • 创建花色数组和点数数组 • 从0开始往HashM ...

随机推荐

  1. CentOS 7 下 安装Webmin 启动防火墙失败----Applying firewall rules:iptables-restore:line 2 failed

    最近学习CentOS 7 系统管理,使用的是<CentOS 6.X系统管理实战宝典>一书------因为网购的CentOS 7 的书还没有送到 O(‘  ’!!)O~ (1)先使用yum方 ...

  2. makefile  模板 (template)

    本文把makefile 分成了三份:生成可执行文件的makefile,生成静态链接库的makefile,生成动态链接库的makefile. 这些makefile都很简单,一般都是一看就会用,用法也很容 ...

  3. C++中 set(集合容器)的用法

    set集合容器: 实现了红黑树(Red-Black Tree)的平衡二叉检索树的数据结构,在插入元素时, 它会自动调整二叉树的排列,把该元素放到适当的位置,以确保每个子树根节点的键值大于左子树所有节点 ...

  4. 数据结构----线性表顺序和链式结构的使用(c)

    PS:在学习数据结构之前,我相信很多博友也都学习过一些语言,比如说java,c语言,c++,web等,我们之前用的一些方法大都是封装好的,就java而言,里面使用了大量的封装好的方法,一些算法也大都写 ...

  5. arm汇编学习(五)

    新增个手写GNU语法arm的方法,以后可以狂逆狂写 hello.S文件 .data msg: .ascii "Hello, ARM!\n" len = . - msg .text ...

  6. 错误的git reset操作之后的补救措施

    (相关命令:git reset.git log.git reflog,要看文档的话用--help.) 这是一次愚蠢的行为之后的总结……避免我之后忘记了解决方法[逃 get reset --hard是一 ...

  7. 【PHP系列】框架的抉择

    缘起 在PHP开发中,选择合适的框架有助于加快软件开发,节约宝贵的项目时间,让开发者专注于功能的实现上.框架的问题是需要很多的投入,选择框架时,我们更看重这个框架的未来,存在多年的大型框架必须要有好的 ...

  8. Python unittest模块心得(二)

    基础概念介绍请参看: http://www.cnblogs.com/frost-hit/p/8295818.html 组织测试用例 unittest.TestSuite(tests=()): 除了使用 ...

  9. 使用 Azure CLI 2.0 从自定义磁盘创建 Linux VM

    本文说明如何在 Azure 中上传自定义的虚拟硬盘 (VHD) 或复制现有 VHD,并从自定义磁盘创建 Linux 虚拟机 (VM). 可以根据要求安装并配置 Linux 分发版,并使用该 VHD 快 ...

  10. 微软在Build 2016开发者大会中发布 “认知服务”,牛津计划有正式名字啦!

    2016年3月30日:微软在Build 2016开发者大会中发布“认知服务”. 在Build 2016开发者大会中,微软发布了新的智能服务:微软认知服务(Microsoft Cognitive Ser ...