(1)52张扑克牌,四种花色(红桃、黑桃、方块和梅花),随机发牌给四个人。

(2)最后将四个人的扑克牌包括花色打印在控制台上。

其中:

    花色和点数用枚举类型实现

    每张扑克牌用结构实现

**************************************************************************************************

[csharp] view
plain
copy



  1. using System;
  2. using System.Collections.Generic;
  3. using System.Collections;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. //用C#模拟实现扑克牌发牌、排序程序。
  8. //(1)52张扑克牌,四种花色(红桃、黑桃、方块和梅花),随机发牌给四个人。
  9. //(2)最后将四个人的扑克牌包括花色打印在控制台上。
  10. //其中:
  11. //  花色和点数用枚举类型实现
  12. //  每张扑克牌用结构实现
  13. //提示:可以用ArrayList初始化52张扑克牌,然后从这个链表中随机取牌发给四个玩家,直到链表为空为止。
  14. namespace Test5
  15. {
  16. enum Color {HongTao=-1,HeiTao=-2,MeiHua=-3,FangPian=-4}//花色
  17. enum Point {A,two,three,four,five,six,seven,eight,nine,ten,J,Q,K}//点数
  18. struct Poker
  19. {//扑克
  20. private string p1,p2;
  21. public Poker(string p1, string p2)
  22. {
  23. // TODO: Complete member initialization
  24. this.p1 = p1;
  25. this.p2 = p2;
  26. }
  27. public void Printp()
  28. {
  29. Console.Write("({0},{1}) ", this.p1,this.p2);
  30. }
  31. }
  32. class Program
  33. {
  34. static void Main(string[] args)
  35. {
  36. Poker po = new Poker();
  37. ArrayList myPoker=new ArrayList();//实例化一个ArrayList存放所有的扑克牌
  38. ArrayList Person1 = new ArrayList();
  39. ArrayList Person2 = new ArrayList();
  40. ArrayList Person3 = new ArrayList();
  41. ArrayList Person4 = new ArrayList();
  42. Random r = new Random();
  43. for (int i = -4; i <= -1; i++)
  44. {//外循环初始化扑克的花色
  45. for (int j = 0; j <= 12; j++)
  46. {//外层循环初始化扑克的点数
  47. myPoker.Add(new Poker(
  48. Enum.GetName(typeof(Color),i),
  49. Enum.GetName(typeof(Point),j)
  50. ));
  51. }
  52. }//for循环结束,52张扑克牌已经生成
  53. Console.WriteLine("打印所有的扑克牌:");
  54. for (int i = 0; i < 52; i++)
  55. {//打印52张生成的扑克牌
  56. Poker poAll = (Poker)myPoker[i];
  57. poAll.Printp();
  58. }
  59. //开始发牌,一个人一个人的发,每发一张牌得从myPoker中RemoveAt掉扑克牌,Count数减小;第一个人Add到一张牌。
  60. for (int i = 0; i < 13; i++)
  61. {
  62. int te = r.Next(0,myPoker.Count);
  63. Person1.Add(myPoker[te]);
  64. myPoker.RemoveAt(te);
  65. }
  66. for (int i = 0; i < 13; i++)
  67. {
  68. int te = r.Next(0, myPoker.Count);
  69. Person2.Add(myPoker[te]);
  70. myPoker.RemoveAt(te);
  71. }
  72. for (int i = 0; i < 13; i++)
  73. {
  74. int te = r.Next(0, myPoker.Count);
  75. Person3.Add(myPoker[te]);
  76. myPoker.RemoveAt(te);
  77. }
  78. for (int i = 0; i < 13; i++)
  79. {
  80. int te = r.Next(0, myPoker.Count);
  81. Person4.Add(myPoker[te]);
  82. myPoker.RemoveAt(te);
  83. }
  84. Console.WriteLine();
  85. Console.WriteLine("打印第一个人的扑克牌:");
  86. for (int i = 0; i < 13;i++ )
  87. {
  88. Poker po1 = (Poker)Person1[i];
  89. po1.Printp();
  90. }
  91. Console.WriteLine();
  92. Console.WriteLine("打印第二个人的扑克牌:");
  93. for (int i = 0; i < 13; i++)
  94. {
  95. Poker po2 = (Poker)Person2[i];
  96. po2.Printp();
  97. }
  98. Console.WriteLine();
  99. Console.WriteLine("打印第三个人的扑克牌:");
  100. for (int i = 0; i < 13; i++)
  101. {
  102. Poker po3 = (Poker)Person3[i];
  103. po3.Printp();
  104. }
  105. Console.WriteLine();
  106. Console.WriteLine("打印第四个人的扑克牌:");
  107. for (int i = 0; i < 13; i++)
  108. {
  109. Poker po4 = (Poker)Person4[i];
  110. po4.Printp();
  111. }
  112. Console.WriteLine();
  113. }
  114. }
  115. }

作者:gcy77 发表于2014-3-12 15:16:24 原文链接
阅读:86 评论:0 查看评论

[原]用C#模拟实现扑克牌发牌、排序程序…的更多相关文章

  1. [原]用C#模拟实现扑克牌发牌、排序程序。

    (1)52张扑克牌,四种花色(红桃.黑桃.方块和梅花),随机发牌给四个人. (2)最后将四个人的扑克牌包括花色打印在控制台上. 其中:     花色和点数用枚举类型实现     每张扑克牌用结构实 ...

  2. C# -- 模拟扑克牌发牌

    C# -- 模拟扑克牌发牌 1.  User 类: 玩家 public class User { private List<PaperCard> listCard = new List&l ...

  3. C算法编程题(一)扑克牌发牌

    前言 上周写<我的编程开始(C)>这篇文章的时候,说过有时间的话会写些算法编程的题目,可能是这两天周末过的太舒适了,忘记写了.下班了,还没回去,闲来无事就写下吧. 因为写C++的编程题和其 ...

  4. Java练习——扑克牌发牌器

    Java练习——扑克牌发牌器声明:学习自其他博主,感谢分享,这里自己也写了一下.实现思路 - 构建一张扑克牌 - 构建一套扑克牌 - 测试  构建一张扑克牌 /** * @author 冬冬 * 定义 ...

  5. Python面向对象编程扑克牌发牌程序,另含大量Python代码!

    1. 题目 编写程序, 4名牌手打牌,计算机随机将52张牌(不含大小鬼)发给4名牌手,在屏幕上显示每位牌手的牌. 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不 ...

  6. Java 扑克牌发牌

    今天看到这个算法题,http://www.cnblogs.com/xishuai/p/3392981.html ,忍不住自己用Java做了一个. 初始化很重要,所有的52张牌按顺序放入到容器里边,标志 ...

  7. HashTable的使用,扑克牌发牌游戏

    l  场景 主要实现以下功能: 1.      首先给扑克牌中每张牌设定一个编号,下面算法实现的编号规则如下:   红桃按照从小到大依次为:1-13   方块按照从小到大依次为:14-26   黑桃按 ...

  8. sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)

    The Android University ACM Team Selection Contest Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里 ...

  9. (待续)C#语言中的动态数组(ArrayList)模拟常用页面置换算法(FIFO、LRU、Optimal)

    目录 00 简介 01 算法概述 02 公用方法与变量解释 03 先进先出置换算法(FIFO) 04 最近最久未使用(LRU)算法 05 最佳置换算法(OPT) 00 简介 页面置换算法主要是记录内存 ...

随机推荐

  1. vim 删除临时文件

    今天在用Xshell连接到CentOS后 使用vim 编辑文档 因为中途有事  临时关闭 并没有保存 再一次打开时 vim 提示要恢复 , 但是每次打开文件后到要恢复,于是找到了以下办法 和vim工作 ...

  2. 用RBG颜色设置自定义颜色

    这个是Mac自带的测色计   快捷键shift + command + c即可复制RBG格式的颜色 #DD0000 这个是csdn 的logo里的红色 我们得到的是十六位颜色代码 但是UIColor( ...

  3. [POJ] 2453 An Easy Problem [位运算]

    An Easy Problem   Description As we known, data stored in the computers is in binary form. The probl ...

  4. [Codeforces Round #237 (Div. 2)] A. Valera and X

    A. Valera and X time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  5. C语言实现OOP 版本3 :简化代码

    我倒是不追求代码和C++相似,但是应该追求简洁的代码,下面是一个新的尝试 shape.h #ifndef SHAPE_H #define SHAPE_H typedef struct shape_t ...

  6. Cmake中的find_package功能

    find_package其实在windows下扮演的角色并不是很重要.在Unix下就非常重要了,find_package可以根据cmake内置的.cmake的脚本去找相应的库的模块,当然,内建了很多库 ...

  7. Network Attack

    Network Attack Nicola regularly inspects the local networks for security issues. He uses a smart and ...

  8. yii基础知识-应用

    应用是指请求处理中的执行上下文.它的主要任务是分析用户请求并将其分派到合适的控制器中以作进一步处理. 它同时作为服务中心,维护应用级别的配置.鉴于此,应用也叫做前端控制器. 应用由 入口脚本 创建为一 ...

  9. 【剑指offer】面试题30:最小的 k 个数

    题目: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 思路: 这个是O(nlogk)时间复杂度的思路:用一个容器来保存最先 ...

  10. python高级编程(第12章:优化学习)2

    #优化策略 #3个原则 """ 1a:寻找其他原因:确定第三方服务器或资源不是问题所在 2a:度量硬件:确定资源足够用 3a:编写速度测试:创建带有速度要求的场景 &qu ...