笔者在大学二年级期间,做过的一次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. 原生js制作标题与内容保持4行的效果

    在制作网页或移动端有时会用到一个效果,类似文章标题和文章描述的排列总是保持一样的行数,要么标题总是一行,多出的省略,要么标题内容1:3或2:2或3:1这样,今天练习这样的效果. 实现的原理:给标题和内 ...

  2. (转) AJAX POST&跨域 解决方案 - CORS

    跨域是我在日常面试中经常会问到的问题,这词在前端界出现的频率不低,主要原因还是由于安全限制(同源策略, 即JavaScript或Cookie只能访问同域下的内容),因为我们在日常的项目开发时会不可避免 ...

  3. <Android 应用 之路> MPAndroidChart~LineChart

    简介 MPAndroidChart是PhilJay大神给Android开发者带来的福利.MPAndroidChart是一个功能强大并且使用灵活的图表开源库,支持Android和IOS两种,这里我们暂时 ...

  4. 第三方库 jsoncpp 读写json

    一.摘要 JSON 的全称为:JavaScript Object Notation,顾名思义,JSON 是用于标记 Javascript 对象的,JSON 官方的解释为:JSON 是一种轻量级的数据传 ...

  5. DELPHI SOKET 编程--使用TServerSocket和TClientSocket

    本文采用delphi7+TServerSocket+TClientSocket; 笔者在工作中遇到对局域网中各工作站与服务器之间进行Socket通信的问题.现在将本人总结出来的TServerSocke ...

  6. Linq批量建表

    public JsonResult CreateTable() { db = new RZBDbContext(); var query = (from c in db.Clients select ...

  7. tp.c

    calculate throughput /* gput.c: out.tr¤ò²òÀϤ·¤Æ¥¹¥ë¡¼¥×¥Ã¥ÈÆÃÀ­¤ò·×»»¤¹¤ë * out.et¤ò²òÀϤ·¤ÆºÆÁ÷¥¿¥ ...

  8. 【jQuery】jQuery中的事件捕获与事件冒泡

    在介绍之前,先说一下JavaScript中的事件流概念.事件流描述的是从页面中接受事件的顺序.   一.事件冒泡( Event Bubbling)            IE 的事件流叫做事件冒泡,即 ...

  9. vagrant 安装虚拟机

    目录 搭建属于你的环境 安装virtualbox 安装 vagrant vagrant 添加系统镜像box 新建虚拟机 相关配置 ==遇到问题== [TOC] 搭建属于你的环境 安装环境有时也是头疼的 ...

  10. Task执行内幕与结果处理解密

    本课主题 Task执行内幕与结果处理解密 引言 这一章我们主要关心的是 Task 是怎样被计算的以及结果是怎么被处理的 了解 Task 是怎样被计算的以及结果是怎么被处理的 Task 执行原理流程图 ...