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 ...
随机推荐
- JavaScript中实现DI的原理(二)
JavaScript中实现DI的原理 在JavaScript中实现DI,看起来难,实际上原理很简单,它的核心技术是Function对象的toString().我们都知道,对一个函数对象执行toStri ...
- GetVersion和GetVersionEx
原文:http://www.cnblogs.com/VOIP/archive/2011/03/22/1990927.html Windows API 中有两个函数可以得到系统版本信息:GetVersi ...
- Spring Boot Async异步执行
异步调用就是不用等待结果的返回就执行后面的逻辑,同步调用则需要等带结果再执行后面的逻辑. 通常我们使用异步操作都会去创建一个线程执行一段逻辑,然后把这个线程丢到线程池中去执行,代码如下: Execut ...
- Android DB类,支持MDB,SQLITE,SQLSERVER,支持查询、事务,对象直接插入和更新操作等
直做数据库,最近花了点时间把自己常用的东西封装在一起. DBHelper using System; using System.Collections.Generic; using System.Te ...
- javax.swing.JComponent 调用顺序
网上截取的,感觉挺有用,记录下来. http://bbs.csdn.net/topics/310041707 java swing 感觉好复杂啊…………一点都不想用但是作业要用到 >_<; ...
- dctcp example-ns2
set N 8 set B 250 set K 65 set RTT 0.0001 set simulationTime 1.0 set startMeasurementTime 1 set stop ...
- XML布局之路
XML布局存放在工程文件的res/layout目录下.安卓和PC端的界面布局有用到. 常用的布局方式,线性布局:LinearLayout 表格布局:TableLayout 帧布局 :FrameLay ...
- Python学习---网络文件上传
中心思想: 传递过去文件的大小,根据文件的大小判断是否文件上传完成: 传递/接受文件采用分流的形式,每次传递/接受部分数据: 文件的读取均采用绝对路径实现,而且是bytes的形式读写 客户端: # ...
- 解决zabbix3.4X图形页面中文乱码
解决zabbix3.4X页面中文乱码 1.在windows的C:\Windows\Fonts找到字体文件simkai.ttf2.在zabbix服务器上找到zabbix默认字体文件graphfont.t ...
- Beta版本 为什么程序员总是分不清万圣节和圣诞节?因为 Oct 31 == Dec 25。
Beta版本 软件的测试版本,经常在各类著名软件中的前期发布版本的后缀中可见,包括大名鼎鼎的windows系统,这个阶段的版本一直加入一些新的功能. 软件测试可分为alpha测试.beta测试和联合测 ...