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. 转:nginx入门指南,快速搭建静态文件服务器和代理服务器

    本文介绍 Nginx 入门基础知识,让你迅速搭建 Nginx 服务器.主要内容包括 Nginx 安装和简单使用.Nginx的简单原理.Nginx 配置文件的结构.如何使用 Nginx 来提供静态文件服 ...

  2. 转:Linux下使用Nginx搭建简单图片服务器

    最近经常有人问图片上传怎么做,有哪些方案做比较好,也看到过有关于上传图片的做法,但是都不是最好的,今天再这里简单讲一下Nginx实现上传图片以及图片服务器的大致理念. 如果是个人项目或者企业小项目,仅 ...

  3. cmd常用命令行

    新建文件夹或文件 打开磁盘     F: 退出cmd     exit 返回上一级     cd.. 创建文件夹     md 文件夹名 在d盘创建文件夹     md d:\文件夹名 在当前目录打开 ...

  4. 51Nod 1081前缀和

    #include <iostream> #include <stdio.h> using namespace std; ]; ]; int main() { int n; ci ...

  5. Topcoder SRM 608 div1 题解

    Easy(300pts): 题目大意:有n个盒子,一共有S个苹果,每个盒子有多少个苹果不知道,但是知道每个盒子的苹果下限和上限.现在要至少选择X个苹果,问如果要保证无论如何都能获得至少X个苹果,至少需 ...

  6. python的tuple()

    描述 Python 元组 tuple() 函数将列表转换为元组. 语法 tuple()方法语法: tuple( seq ) 参数 seq -- 要转换为元组的序列. 返回值 返回元组. 实例 以下实例 ...

  7. [BZOJ3261&BZOJ3166]可持久化trie树及其应用

    可持久化trie树 可持久化trie树现在想来是比较好理解的了,但却看了一个下午... 相当于对于每个状态建立一条链(或者说一棵trie),求解的时候只要让两个点按照相同的步子走然后看sum的大小关系 ...

  8. Splunk笔记

    学习Splunk Fundamentals Part 2 (IOD) 和 Splunk Fundamentals Part 1课程的笔记. Chart Over By Tips: ….|chart c ...

  9. UVA 10668 Expanding Rods

    Problem A: Expanding Rods When a thin rod of length L is heated n degrees, it expands to a new lengt ...

  10. (十四)git操作

    https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000