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. svn“Previous operation has not finished; run 'cleanup' if it was interrupted“ 或者不能cleanup,或者提示空目录 报错的解决方法

    参考了文档: http://blog.csdn.net/superch0054/article/details/38668017 今天碰到了个郁闷的问题,svn执行clean up命令时报错“Prev ...

  2. jquery中的get和post、ajax有关返回值的问题描述

    一:前言 今天我就要离开公司回学校准备考试,在走之前,我自己做的一个模块测试除了一些小的bug.问题如下 我在往数据库中插入数据,首先要选择一级菜单,接着会更具一级菜单生成一级菜单的子目录,在选择日期 ...

  3. 51Nod 1118 机器人走方格--求逆元

    (x/y) %mod =x*(y^(mod-2))%mod; 在算x,y的时候可以一直mod 来缩小 y^(mod-2)显然是个快速幂 #include <iostream> #inclu ...

  4. 【BZOJ2738】矩阵乘法 [整体二分][树状数组]

    矩阵乘法 Time Limit: 20 Sec  Memory Limit: 256 MB[Submit][Status][Discuss] Description 给你一个N*N的矩阵,不用算矩阵乘 ...

  5. 【BZOJ1996】【HNOI2010】合唱队 [区间DP]

    合唱队 Time Limit: 4 Sec  Memory Limit: 64 MB[Submit][Status][Discuss] Description Input Output Sample ...

  6. bzoj 1064 图论

    我们根据能否看见建图,有向图边权设成1,然后我们转成无向图, 对于每条有向边连一条反边,边权是-1,然后从每个块中任意一个点开始 dfs,每个点有一个值,经过一条边到另一个点之后,用原来的点值和边权 ...

  7. hdu 4506 小明系列故事——师兄帮帮忙

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4506 题目大意:找规律,判断k的t次幂前面的系数. #include <iostream> ...

  8. MySQL 进阶(待发布)

    视图 存储过程 触发器 基本函数

  9. IOS开发代码分享之获取启动画面图片的string

    http://www.jb51.net/article/55309.htm 本代码支持 iPhone 6 以下. 支持 iPhone 及 iPad ? 1 2 3 4 5 6 7 8 9 10 11 ...

  10. Oracle基础 03 回滚表空间 undo

    --查询默认的undo表空间 select name,value from v$parameterwhere name like '%undo%'; --创建 undotbs2 表空间 create ...