当前位置: 首页 > news >正文

有想做企业网站建设推广公众号

有想做企业网站建设,推广公众号,彩票网站链接怎么做,注册城乡规划师考试教材【案例6-4】 斗地主洗牌发牌 【案例介绍】 1.任务描述 扑克牌游戏“斗地主”,相信许多人都会玩,本案例要求编写一个斗地主的洗牌发牌程序,要求按照斗地主的规则完成洗牌发牌的过程。一副扑克总共有54张牌,牌面由花色和数字组成…

【案例6-4】 斗地主洗牌发牌

【案例介绍】

1.任务描述

扑克牌游戏“斗地主”,相信许多人都会玩,本案例要求编写一个斗地主的洗牌发牌程序,要求按照斗地主的规则完成洗牌发牌的过程。一副扑克总共有54张牌,牌面由花色和数字组成(包括J、Q、K、A字母)组成,花色有♠、♥、♦、♣ 四种,分别表示黑桃、红桃、方块、梅花,小☺、大☻分别表示小王和大王。斗地主游戏共有3位玩家参与,首先将这54张牌的顺序打乱每人轮流摸一次牌,剩余3张留作底牌,然后在控制台打印3位玩家的牌和3张底牌。

2.运行结果

 任务运行结果如图6-1所示:

图6-1  运行结果图

 

【实现思路】

(1)要实现纸牌程序,首先需要完成纸牌的组装。牌面是由花色(包括♠、♥、♦、♣花色)和数字(包括J、Q、K、A字母)两部分组成,可以创建两个ArrayList集合作为花色集合与数字集合,存储时需要注意。比10大的牌的数字用J、Q、K表示,1用A表示。

(2)将花色集合与数字集合这两个循环进行嵌套循环,将花色与数字组合,形成52章牌,并赋予其编号。将组合后的牌存放到一个HashMap集合中,集合的Key值是编号,value值是组装完成的纸牌。还有两张牌是大小王(小☺表示小王、大☻表示大王)。由于组装规则不一致,需单独使用add()方法将这两张牌加入到HashMap集合中。

(3)创建一个数字集合,用这个数字集合代替纸牌完成洗牌和发牌操作。由于纸牌的数量是54张,所以创建集合范围是0~53。 

(4)可以使用Collection类的shuffle()方法完成打乱数字集合的操作,实现洗牌效果。由于只有3个人,所以可以使用for循环,通过将数字与3取余的方法,将代表不同纸牌的数字分配给不同人与底牌,实现发牌效果。

(5) 洗牌和发牌结束后,可以通过Collection类的sort()方法完成排序,之后通过foreach()循环HashMap集合,根据数字查找对应的纸牌字符串,并存入创建的字符串集合中,最后展示字符串集合。

【实现代码】

程序实现代码如文件6-1所示。 

                         文件6-1  example5.java

  1. package com.itheima;
  2. import java.util.ArrayList;
  3. import java.util.Collections;
  4. import java.util.HashMap;
  5. public class example {
  6.     public static void main(String[] args) {
  7.         // 准备花色
  8.         ArrayList<String> color = new ArrayList<String>();
  9.         color.add("♠");
  10.         color.add("♥");
  11.         color.add("♦");
  12.         color.add("♣");
  13.         // 准备数字 ,ArrayList将纸牌由小到大排序
  14.         ArrayList<String> number = new ArrayList<String>();
  15.         for (int i = 3; i <= 10; i++) {
  16.            number.add(i + "");
  17.         }
  18.         number.add("J");
  19.         number.add("Q");
  20.         number.add("K");
  21.         number.add("A");
  22.         number.add("2");
  23.         // 定义一个map集合:用来将数字与每一张牌进行对应
  24.        HashMap<Integer, String> map = new HashMap<Integer, String>();
  25.          int index = 0;// 纸牌编号
  26.         for (String thisNumber : number) {// 循环纸牌数字
  27.            for (String thisColor : color) {// 循环纸牌花色
  28.                // 将花色与数字组合,形成52张牌,并赋予其编号
  29.                map.put(index++, thisColor + thisNumber);
  30.            }
  31.         }
  32.         // 加入大小王
  33.         map.put(index++, "");
  34.         map.put(index++, "☻");
  35.         // 一副54张的牌 ArrayList里边为0-53的数的新牌
  36.         ArrayList<Integer> cards = new ArrayList<Integer>();
  37.         for (int i = 0; i <= 53; i++) {
  38.            cards.add(i);// 此时的cards顺序为0-53
  39.         }
  40.         // 洗牌,使用Collections工具类中的shuffle()方法
  41.         Collections.shuffle(cards);// 此时的cards顺序已被打乱
  42.         // 创建三个玩家和底牌
  43.         ArrayList<Integer> iPlayer = new ArrayList<Integer>();
  44.         ArrayList<Integer> iPlayer2 = new ArrayList<Integer>();
  45.         ArrayList<Integer> iPlayer3 = new ArrayList<Integer>();
  46.         ArrayList<Integer> iSecretCards = new ArrayList<Integer>();
  47.         // 遍历这副洗好的牌,遍历过程中,将牌发到三个玩家和底牌中
  48.         for (int i = 0; i < cards.size(); i++) {
  49.            if (i >= 51) {
  50.                iSecretCards.add(cards.get(i));// 留取3张底牌
  51.            } else {
  52.                if (i % 3 == 0) {
  53.                  iPlayer.add(cards.get(i));//3取余为0的牌发给玩家1
  54.                } else if (i % 3 == 1) {
  55.                  iPlayer2.add(cards.get(i));//3取余为1的牌发给玩家2
  56.                } else {
  57.                    iPlayer3.add(cards.get(i));// 其余的牌发给玩家3
  58.                }
  59.            }
  60.         }
  61.         // 对每个人手中的牌排序,使用Collections工具类中的sort()方法
  62.         Collections.sort(iPlayer);
  63.         Collections.sort(iPlayer2);
  64.         Collections.sort(iPlayer3);
  65.         // 对应数字形式的每个人手中的牌,定义字符串形式的牌
  66.         ArrayList<String> sPlayer = new ArrayList<String>();
  67.         ArrayList<String> sPlayer2 = new ArrayList<String>();
  68.         ArrayList<String> sPlayer3 = new ArrayList<String>();
  69.         ArrayList<String> sSecretCards = new ArrayList<String>();
  70.         // 循环主键,从map中获取纸牌
  71.         for (Integer key : iPlayer) {
  72.            sPlayer.add(map.get(key));
  73.         }
  74.         for (Integer key : iPlayer2) {
  75.            sPlayer2.add(map.get(key));
  76.         }
  77.         for (Integer key : iPlayer3) {
  78.            sPlayer3.add(map.get(key));
  79.         }
  80.         for (Integer key : iSecretCards) {
  81.            sSecretCards.add(map.get(key));
  82.         }
  83.            // 看牌
  84.            System.out.println("玩家1" + sPlayer);
  85.            System.out.println("玩家2" + sPlayer2);
  86.            System.out.println("玩家3" + sPlayer3);
  87.            System.out.println("底牌:" + sSecretCards);
  88.         }
  89. }

在文件6-1中,第8~22行代码将4种花色和13个纸牌编号分别放到两个ArrayList集合中。第24~34当代码foreach循环拼出52张纸牌,并将其依照从小到大的顺序放入Map集合中,并将大小王添加到其中。第36~41行代码创建了代替纸牌的数字集合,将其与纸牌中的序号对应,并将数字集合中的顺序打乱,此时集合相当于纸牌编号集合。第43~60行代码完成了将纸牌编号发给3位玩家并留3张纸牌编号做为底牌的操作。第62~64行代码将3位玩家手中纸牌编号进行排序。第66~88行代码通过循环3位玩家手中的纸牌编号,将纸牌字符串从Map中取出放入字符串集合。最后打印字符串集合,分别得到3个玩家的纸牌和底牌。

 

http://www.15wanjia.com/news/57142.html

相关文章:

  • 东莞视频网站制作今日军事新闻头条视频
  • 刷赞网站推广软件网站维护工程师
  • 1核2g 做网站seo排名哪家正规
  • 网站功能报价明细表最近国内新闻
  • 并提示网站菜单导航及用户登录互联网站
  • 友点企业网站管理系统模板seo排名需要多少钱
  • 卖辅助网站怎么做的百度seo排名如何提升
  • b2b平台查询seo快速整站上排名教程
  • 自己做网站要买服务器信息流广告投放流程
  • wordpress 购物网站主题seo网站优化培训厂家报价
  • dw网站首页制作大连网络推广公司哪家好
  • 怎样在美国做网站热门关键词排名查询
  • 网站的ftp账号和密码是什么南宁seo网络优化公司
  • 公司网站文章的排版建站模板哪个好
  • 移动办公型网站开发1688黄页大全进口
  • 2022年互联网创业项目关键词优化的策略
  • 给企业建设网站的流程图百度推广怎么收费标准
  • 微信网站开发语言网络营销公司热线电话
  • 网站制作 福宁网络有限公司百度打广告多少钱
  • 上海 房地产网站建设网站排名优化需要多久
  • 上海网站建设 paiky优化法治化营商环境
  • 企业网站建设算什么费用网站引流推广
  • 可以做招商的网站我要软文网
  • 买完域名怎么创建网站怎么制作网站平台
  • 无锡网站定制四川自助seo建站
  • 女生做网站编辑百度地图导航
  • 做公司网站利润网络营销ppt课件
  • 商标购买网站抖音seo排名系统
  • 免费详情页模板网站网络舆情监控系统
  • 四川高速公路建设开发集团有限公司网站百度老旧版本大全