52张牌随机分给4个玩家,要求每个玩家的牌用一个一维数组表示。

我们采用模拟大法。初始化一副扑克牌,洗牌,发牌。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace ConsoleApplication43
{ class Program
{
enum Suit
{
Spade, Heart, Diamond, Club
}
enum Value
{
Two, Three, Four, Five, Six, Seven, Eight, Nine, Ten, Jack, Queue, King, Ace
}
class Card
{
public Suit suit;
public Value value;
}
static void Main(string[] args)
{
Card[] c = new Card[];
for(int i=;i<;i++) ///初始化一副扑克牌
{
c[i] = new Card();
c[i].suit = (Suit)(i % );
c[i].value = (Value)(i % );
}
for (int k=; k >=; k--) //洗牌
{
Random rand = new Random();
int p = rand.Next(k);
Card temp=new Card ();
temp = c[p];
c[p] = c[k];
c[k] = temp;
}
Card[] E = new Card[]; Card[] W = new Card[];
Card[] S = new Card[]; Card[] N = new Card[];
int A=,B=,C=,D=;
for(int j=;j<;j++)//分牌
{
switch(j%)
{
case : { E[A++] = c[j]; break; }
case : { S[B++] = c[j]; break; }
case : { W[C++] = c[j]; break; }
case : { N[D++] = c[j]; break; }
default: { Console.WriteLine("error"); break; }
}
}
Console.WriteLine("东:");
for (int i = ; i < ; i++)
{ Console.Write("{0},{1} ", E[i].suit, E[i].value);}
Console.WriteLine();
Console.WriteLine("南:");
for (int i = ; i < ; i++)
{ Console.Write("{0},{1} ", S[i].suit, S[i].value);}
Console.WriteLine();
Console.WriteLine("西:");
for (int i = ; i < ; i++)
{ Console.Write("{0},{1} ", W[i].suit, W[i].value);}
Console.WriteLine();
Console.WriteLine("北:");
for (int i = ; i < ; i++)
{ Console.Write("{0},{1} ", N[i].suit, N[i].value);}
}
}
}
 练习:电脑随机发出5张牌,判断是以下哪种牌型?(梭哈游戏的基础)
 
 

同花顺
(Straight Flush亦称“蛇”):同一花色,顺序的牌。
例:

  

  

  

  

  

四条(Four of a Kind,亦称“铁支”、“四张”或“炸弹”):有四张同一点数的牌。
例:

  

  

  

  

  

满堂红(Fullhouse,亦称“俘虏”、“骷髅”、“夫佬”、“葫芦”、“富尔豪斯”):三张同一点数的牌,加一对其他点数的牌。
例:

  

  

  

  

  

同花(Flush,简称“花”:五张同一花色的牌。
例:

  

  

  

  

  

顺子(Straight,):五张顺连的牌。
例:

  

  

  

  

  

三条(Three of a kind,亦称“三张”):有三张同一点数的牌。
例:

  

  

  

  

  

两对(Two Pairs,香港称“Two啤”):两张相同点数的牌,加另外两张相同点数的牌。
例:

  

  

  

  

  

一对(One Pair,香港称“啤”):两张相同点数的牌。
例:

  

  

  

  

  

无对(Zilch ,香港称“粒”):不能排成以上组合的牌,以点数决定大小。
例:

  

  

  

  

  

 
 

理解面向对象编程---C#控制台实现52张扑克牌的分法的更多相关文章

  1. Java 雇员管理小练习(理解面向对象编程)

    在学习集合框架的时候,初学者很容易练习到学生管理系统.雇员管理体统等练习题.在学习集合框架之前,基本上Java基本语法都学完了,集合框架也从侧面的检验对前面学习的理解.下面用一个曾经做过的练习题,回顾 ...

  2. Java 用LinkdeList实现52张扑克牌

    用LinkdeList实现52张扑克牌(不含大小王)的洗牌功能.提示:花色 ,和数字分别用数组存储. import java.util.LinkedList; import java.util.Ran ...

  3. 从一些简单代码实例彻底理解面向对象编程思想|OOP本质是什么?

    从Rob Pike 的 Google+上的一个推看到了一篇叫<Understanding Object Oriented Programming>的文章,我先把这篇文章简述一下,然后再说说 ...

  4. SwiftUI:看我展示52张扑克牌,“很快啊!”

    目录 思路 效果图 相关代码解析 枚举创建扑克牌号码 枚举创建扑克牌类型 viewModel逻辑 UI实现 源码 感受 思路 使用 SwiftUI 创建 UI 结构: 使用 swift 的枚举和结构体 ...

  5. 52张扑克牌快速生成js

    function* generatePoker() { const points = ['A', 2, 3, 4, 5, 6, 7, 8, 9, 10, 'J', 'Q', 'K']; yield* ...

  6. JavaScript基础入门12 - 面向对象编程

    目录 JavaScript 面向对象编程 前言 构造函数创建对象 instanceof constructor 返回值 原型对象 关于对象的属性查找 in hasOwnProperty() JS当中实 ...

  7. 1.面向过程编程 2.面向对象编程 3.类和对象 4.python 创建类和对象 如何使用对象 5.属性的查找顺序 6.初始化函数 7.绑定方法 与非绑定方法

    1.面向过程编程 面向过程:一种编程思想在编写代码时 要时刻想着过程这个两个字过程指的是什么? 解决问题的步骤 流程,即第一步干什么 第二步干什么,其目的是将一个复杂的问题,拆分为若干的小的问题,按照 ...

  8. python面向对象编程学习

    python面向对象编程 基本概念理解 面向对象编程--Object Oriented Programming,简称OOP,是一种程序设计思想.OOP把对象作为程序的基本单元,一个对象包含了数据和操作 ...

  9. Python基础 — 面向对象编程基础

    目录 1. 面向对象编程基础 2. 定义类和创建对象 3. init() 方法 4. 魔法方法 5. 访问可见性问题 5. 练习 1. 面向对象编程基础 把一组数据结构和处理它们的方法组成对象(obj ...

随机推荐

  1. bzoj1053 搜索

    2013-11-16 17:43 原题传送门http://www.lydsy.com/JudgeOnline/problem.php?id=1053 因为使pi(prime[i])<20亿的i不 ...

  2. Bcrypt介绍

    Bcrypt把算法版本.计算次数和salt都放到hash值里面去了 Stored in the database, a bcrypt "hash" might look somet ...

  3. LeetCode 151 reverse word in a string

    Given an input string, reverse the string word by word. For example, Given s = "the sky is blue ...

  4. WScript.Shell对象的 run()和exec()函数使用详解

    WScript.Shell对象的 run()和exec()函数使用详解 http://blog.sina.com.cn/s/blog_6e14a2050102v47g.html   vbScript ...

  5. js 各种取整方式及方法

    1.直接丢弃小数部分,保留整数部分 a:parseInt(1.5555) b: 0|1.5555 2.向上取整 a: Math.ceil(1.5555) b: (1.5555+0.5).toFixed ...

  6. 快速搭建YUM源和yum使用

    yum是一种便捷,快速的RPM包安装方法,可以避免很多包的关联性,但RedHat的YUM源,不是免费的,需要他们的RHN才能够用,而CentOS得yum是免费的,由于CentOS和RedHat相似度高 ...

  7. Selenium2+python自动化71-多个浏览器之间的切换【转载】

    前言 有时候一些业务的功能涉及到多个系统,需要在web系统1打开造一些数据,然后用到某些参数是动态生成的,需要调用web系统2里面的参数. 举个简单例子:在做某些业务的时候,需要手机短信验证码,我不可 ...

  8. 【hdoj_2124】RepairTheWall

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2124 思路:贪心法.由于要求所需的块儿(block)的最小数目,先把所有的块儿加起来,看看大小是否> ...

  9. Zookeeper概念学习系列之zookeeper实现分布式共享锁

    首先假设有两个线程, 两个线程要同时到mysql中更新一条数据, 对数据库中的数据进行累加更新.由于在分布式环境下, 这两个线程可能存在于不同的机器上的不同jvm进程中, 所以这两个线程的关系就是垮主 ...

  10. 大数据量的Mysql数据库备份策略

    Centos下mysql常用的三种备份方法 http://www.centoscn.com/CentOS/Intermediate/2013/0807/1160.html xtrabackup备份 h ...