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=13;
 static const int totalSuits=4;

 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","2","3","4","5","6","7","8","9","10","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=5;
 static const int allCards=52;
 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=0;i<allCards;i++)
 {
  Card card(i%Card::totalFaces,i/Card::totalFaces);
  deck.push_back(card);
 }
}

void DeckOfCards::shuffle()
{
 srand(time(0));

 int swapRandom[allCards];

 for(int i=0;i<allCards;i++)
  swapRandom[i]=int(rand())%allCards;

 for(int i=0;i<allCards;i++)
 {
  Card swapCard(0,0);
  swapCard=deck[i];
  deck[i]=deck[swapRandom[i]];
  deck[swapRandom[i]]=swapCard;
 }

}

Card DeckOfCards::dealCard(int how_many)
{
 for(int i=0;i<how_many;i++)
 {
  cout <<deck[i].toString() <<endl;
  if((i+1)%13==0) cout <<endl;
 }
}

void DeckOfCards::sortCards()
{
 int sortFaces[fiveCards];
 int sortSuits[fiveCards];
 for(int i=0;i<fiveCards;i++)
 {
  sortFaces[i]=deck[i].getFace();
  sortSuits[i]=deck[i].getSuit();
 }

 for(int i=fiveCards-1;i>=0;i--)
  for(int j=0;j<=i-1;j++)
   if(sortFaces[j]>sortFaces[j+1])
   {
    int t;
    t=sortFaces[j];
    sortFaces[j]=sortFaces[j+1];
    sortFaces[j+1]=t;
   }

 if((sortFaces[0]==sortFaces[1]&&sortFaces[0]==sortFaces[2]&&sortFaces[0]==sortFaces[3])||
  (sortFaces[1]==sortFaces[2]&&sortFaces[1]==sortFaces[3]&&sortFaces[1]==sortFaces[4]))
  cout <<"There are 4 same cards." <<endl;

 else if((sortFaces[0]==sortFaces[1]&&sortFaces[0]==sortFaces[2])||
   (sortFaces[1]==sortFaces[2]&&sortFaces[1]==sortFaces[3])||
   (sortFaces[2]==sortFaces[3]&&sortFaces[2]==sortFaces[4]))
  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[0]+1==sortFaces[1]&&sortFaces[1]+1==sortFaces[2]&&
  sortFaces[2]+1==sortFaces[3]&&sortFaces[3]+1==sortFaces[4])
  cout <<"The five cards is a straight." <<endl;
 else
  cout <<"The five cards is not a straight." <<endl;

 if(sortSuits[0]==sortSuits[1]&&sortSuits[0]==sortSuits[2]&&
  sortSuits[0]==sortSuits[3]&&sortSuits[0]==sortSuits[4])
  cout <<"The five cards have same flower." <<endl;
 else
  cout <<"The five cards have different flower." <<endl;

}

int DeckOfCards::duiziCards(int* sortFaces)
{
 int duiziNum=0;

 for(int i=0;i<fiveCards-1;i++)
  if(sortFaces[i]==sortFaces[i+1]) 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 0;
}

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C++实现洗牌发牌排序功能的示例代码

    在内存中模拟出一副牌,然后模拟洗牌,发牌等动作. 流程是这样的:构建一副牌保存到一个数组中-洗牌-创建玩家-向玩家发牌–输出每个玩家的牌. #include <stdio.h> #include <stdlib.h> #include <time.h> //定义扑克的花色 enum Suit{ heart, spade, diamond, club, joker1, joker2 }; //一副牌的数量 #define CARD_COUNT 54 //定义扑克 type

  • 使用C语言求解扑克牌的顺子及n个骰子的点数问题

    扑克牌的顺子     问题描述:从扑克牌中随机抽5张牌,判断是不是一个顺子,即这5张牌是不是连续的.2-10为数字本身,A为1,J为11,Q为12,K为13,而大小王可以看成任意数字.          思路:可以将这5张牌排个序,然后统计出0的个数以及非0数字之间的间隔数,如果出现重复的非0数字,那么不是顺子.如果间隔数小于等于0的个数,那么是顺子.暂时未想到更好的办法.          参考代码: //函数功能 : 从扑克牌中随机抽5张牌,判断是不是一个顺子 //函数参数 : pCards

  • C++扑克牌的洗牌发牌游戏设计

    笔者在大学二年级期间,做过的一次C++程序设计:扑克牌的洗牌发牌游戏.具体内容是:除去大王和小王,将52张扑克牌洗牌,并发出5张牌.然后判断这5张牌中有几张相同大小的牌,是否是一条链,有几个同花等. 笔者在学习他人设计的基础上,完成了自己的程序设计.这里将源程序分享给大家. [1] 文件"card.h" #ifndef CARD_H #define CARD_H #include<string> using namespace std; class Card { publi

  • C语言编写洗牌发牌程序

    用C语言编写洗牌发牌程序,供大家参考,具体内容如下 题目 现在只有一套扑克牌中52张副牌(无大王小王),包含了4种花色的牌 现在打乱顺序后分给甲乙丙丁四人 全部分配完毕后,输出甲乙丙丁四人所获得的扑克大小及花色 再经过排序,将甲乙丙丁四人的牌按由大到小顺序输出到屏幕上 要素提取 略 补充 牌面上的数字/字母由小到大为: 3 4 5 6 7 8 9 10 J Q K A 2 牌面上的花色由小到大为: 方块 梅花 红桃 黑桃 思路 略 可能出现的问题 略 代码 #include<stdio.h>

  • Java超详细教你写一个斗地主洗牌发牌系统

    目录 一.斗地主 1.前言 2.介绍 3.图解 二.准备牌 1.代码示例 2.数据展示 三.洗发牌与排序 代码示例 四.看牌(打印到控制台) 1.代码示例 2.展示 六.总结 一.斗地主 1.前言 相信每位看过<赌神>的同学都知道,里面有一种神奇的类似于魔术的力量. 没错!我们今天要说的这个神奇的东西就是:特异功能(不是) 就是:斗地主的洗牌发牌系统!!! 2.介绍 扑克牌经典游戏"斗地主"相信很多人都会玩,这次就用Java语言来编写一个斗地主的洗牌发牌程序,要求按照斗地主

  • C语言实现洗牌发牌小程序

    本文实例为大家分享了C语言实现洗牌发牌小程序的具体代码,供大家参考,具体内容如下 构建一副扑克牌,并实现洗牌发牌. 代码 #include <stdio.h> #include <time.h> #include <stdlib.h> #define NUM 10000 //洗牌混乱度 char color[7][7] = {"空白","红桃","黑桃","草花","方片"

  • Java实现洗牌发牌的方法

    本文实例讲述了Java实现洗牌发牌的方法.分享给大家供大家参考.具体如下: import java.util.*; public class Main { /** * @param args the command line arguments */ static int numbersOfPlayers = 4; static int numbersOfHandCard = 13; public static void main(String[] args) { // TODO code ap

  • python小程序之4名牌手洗牌发牌问题解析

    本文为大家解析了python实现4名牌手洗牌发牌的问题,供大家参考,具体内容如下 编写程序, 4名牌手打牌,计算机随机将52张牌(不含大小鬼)发给4名牌手,在屏幕上显示每位牌手的牌.创建函数gen_pocker()交换牌的顺序,函数getColor()获取牌的花色,函数getValue()获取牌的牌面大小,函数getPuk()获取花色和牌面大小的组合 运行效果 [51, 45, 31, 4, 48, 26, 11, 2, 24, 44, 22, 21, 16, 41, 50, 47, 13, 2

  • Java实现斗地主之洗牌发牌

    本文通过实例为大家分享了Java实现斗地主之洗牌发牌的具体代码,供大家参考,具体内容如下 案例分析 需求: 实现斗地主过程中的洗牌,发牌和看牌. 并且确保每一位玩家手上拿到的牌是随机并且按照大小排序好的 思路 1.创建一个牌盒,也就是定义一个集合对象,用ArrayList集合实现 2.往牌盒里面装牌 3.洗牌,也就是把牌打散,用Collections的shuffle()方法实现 4.发牌,也就是遍历结合,给三个玩家发牌 5.看牌,也就是三个玩家分别遍历自己的牌 代码实现 1.创建牌盒,存放所有牌

  • Java模拟实现扑克牌洗牌和发牌的示例代码

    目录 一. 需求 二. 全局代码 poker.java pokers.java 三. 设计分析 1. 设计一张扑克牌 2. 得到一副新牌 3. 洗牌 4. 发牌 一. 需求 设计一副新的的扑克牌, 4个花色(♥, ♠, ♦, ♣)对应 1 到 13 , 不算大小王一共52张牌 ; 然后将扑克牌随机打乱顺序 , 最后实现三个人进行摸牌 , 三个人轮流进行摸牌(每次摸一张牌) , 最终每个人手里有五张牌 二. 全局代码 poker.java public class poker { private

  • Java实现扑克牌洗牌和发牌

    本文实例为大家分享了Java实现扑克牌洗牌发牌的具体代码,供大家参考,具体内容如下 实现原理:使用4种花色和13个数字组合成52张牌,放进一个集合中:通过把集合数据排序打乱实现洗牌操作,然后在通过循环把牌抽出来实现发牌操作. 下面是实现代码: import java.util.ArrayList; import java.util.Collections; public class Card { private static ArrayList<String> list = new Array

随机推荐