C++分享笔记:扑克牌的洗牌发牌游戏设计
笔者在大学二年级期间,做过的一次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++分享笔记:扑克牌的洗牌发牌游戏设计的更多相关文章
- java斗地主扑克 扑克牌 洗牌 发牌 Collection 集合练习
package com.swift.poker; import java.util.ArrayList; import java.util.Collections; /*训练考核知识点:Collect ...
- 实现斗地主纸牌游戏---洗牌 发牌 看底牌的具体功能------Map集合存储方法 遍历的应用
该Demo只是斗地主的游戏的一部分,实现的斗地主的组合牌 洗牌 发牌 看牌的功能,主要应用Map集合进行练习 package cn.lijun import java.util.ArrayList ...
- Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)
规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java ...
- JAVA程序设计(11)-----面对对象0基础设计 麻将 创建麻将牌 然后洗牌 发牌~ 恩 就这样
zzzzZZZZ 1.開始还想贴图的 实在太懒了-- 这是一张麻将 package com.lovo; import java.awt.Graphics; import java.awt.Image; ...
- java——斗地主小游戏之洗牌发牌
遇到的问题: 1.int和Integer的区别? 1)Integer是int的包装类,int则是java的一种基本数据类型 . 2)Integer变量必须实例化后才能使用,而int变量不需要 . 3) ...
- 算法笔记_128:完美洗牌算法(Java)
目录 1 问题描述 2 解决方案 2.1位置置换算法 2.2 走环算法 1 问题描述 有一个长度为2n的数组{a1,a2,a3,...,an,b1,b2,b3,...,bn},希望排序后变成{a1 ...
- java 模拟斗地主发牌洗牌
一 模拟斗地主洗牌发牌 1.案例需求 按照斗地主的规则,完成洗牌发牌的动作. 具体规则: 1. 组装54张扑克牌 2. 将54张牌顺序打乱 3. 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张 ...
- java集合--模拟斗地主发牌洗牌
import java.util.*; /** * @Date: 2020/6/17 19:53 */public class Test04 { public static void main(Str ...
- Java基础知识强化之集合框架笔记71:模拟斗地主洗牌和发牌并对牌进行排序的案例
1. 模拟斗地主洗牌和发牌并对牌进行排序的原理图解: 2. 代码实现: 思路: • 创建一个HashMap集合 • 创建一个ArrayList集合 • 创建花色数组和点数数组 • 从0开始往HashM ...
随机推荐
- CentOS 7运维管理笔记(6)----Apache 基于 IP 的虚拟主机配置
Apache 配置虚拟主机支持3种方式:基于IP的虚拟主机配置,基于端口的虚拟主机配置,基于域名的虚拟主机配置.本篇随笔记录自己基于IP的虚拟主机配置. 如果同一台服务器有多个IP,可以使用基于IP的 ...
- 【转载】javascript深入理解js闭包
一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...
- Git学习-Git配置(一)
零.前言 Git是一个工具,就没必要把时间浪费在那些"高级"但几乎永远不会用到的命令上.一旦你真的非用不可了,到时候再自行Google或者请教专家也未迟. 如果你是一个开发人员,想 ...
- 使用C++11实现完美资源管理
1.资源管理包括内存管理.文件句柄等等需要进行打开(申请).关闭(释放)操作的过程 2.VS2010使用的C++规范,严格说来不是C++11,而是C++0x,但是一脉相承的 一:管理数组 相较于aut ...
- 微软智能云的核心DNA
你知道吗? 今天,微软智能云平台运行于全球30个区域,体量超过了两大云服务商亚马逊和谷歌的总和: 今天,在全球范围内超过85%的财富五百强企业都使用了微软Azure云服务,而中国部分的用户也达到了六万 ...
- SQL Server ->> Database Snapshot(数据块快照)
Comming soon!!! 参考文献: View the Size of the Sparse File of a Database Snapshot 数据库快照 (SQL Server) 创建数 ...
- mongodb 3.4复制搭建
mongodb数据库主从复制的原理:在主从结构中,主节点的操作记录称为oplog(operation log).oplog存储在一个系统数据库local的集合oplog.$main中,这个集合的每个文 ...
- python多进程与协程
1.进程的概念 什么是进程->CPU在同一时刻只能处理一个任务,只是因为cpu执行速度很快. cpu在各个任务之间来回的进行切换. 进程的概念:正在进行的一个过程或者说一个任务,而负责执行任务的 ...
- Linux->Ubuntu配置tomcat开机自动启动
Ubuntu配置tomcat开机自动启动 我们有时候会有这样一个需求: 在开机的时候就启动一个服务,比如tomcat. 我们可以这样做: 将tomcat目录下/bin中的catalina.sh拷贝到/ ...
- [翻译] iOS开发工具的介绍(第一部分)
IOS DEVELOPMENT TIPS & TRICKS - PART I http://blog.trifork.com/2013/12/19/ios-development-tips-t ...