斗地主的综合案例实现(Map有序)

整体思路

代码实现

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; /*
斗地主综合案例:有序版本
1.准备牌
2.洗牌
3.发牌
4.排序
5.看牌
*/ public class Demo05Test {
public static void main(String[] args) {
//1.准备牌
//创建一个Map集合,存储牌的索引和组装好的牌
HashMap<Integer, String> map = new HashMap<>();
//创建一个List集合,存储牌的索引
ArrayList<Integer> list1 = new ArrayList<>();
//定义两个数组,存储花色和牌的序号
String[] colors = {"","","",""};
String[] numbers = {"2","A","K","Q","J","10","9","8","7","6","5","4","3"};
//把大王和小王存储到集合中
//定义一个牌的索引
int index=0;
map.put(index,"大王");
list1.add(index);
index++;
map.put(index,"小王");
list1.add(index);
index++;
//循环嵌套遍历两个集合,组装52张牌,存储到集合中
for (String number : numbers) {
for (String color : colors) {
map.put(index,color+number);
list1.add(index);
index++;
}
} /*
2.洗牌
使用Collections中的方法shuffle(list)
*/
Collections.shuffle(list1); /*
3.发牌
*/
//定义4个集合,存储玩家牌的索引,和底牌的索引
ArrayList<Integer> player01 = new ArrayList<>();
ArrayList<Integer> player02 = new ArrayList<>();
ArrayList<Integer> player03 = new ArrayList<>();
ArrayList<Integer> dipai = new ArrayList<>();
//遍历存储牌索引的List集合,获取每一个牌的索引
for (int i1 = 0; i1 < list1.size(); i1++) {
Integer j = list1.get(i1);
//先判断底牌
if (i1>=51){
//给底牌发牌
dipai.add(j);
}else if (i1%3==0){
//给玩家1发牌
player01.add(j);
}else if (i1%3==1){
//给玩家2发牌
player02.add(j);
}else if (i1%3==2){
//给玩家3发牌
player03.add(j);
}
} /*
4.排序
使用Collections中的方法sort(list)
默认是升序排序
*/ Collections.sort(dipai);
Collections.sort(player01);
Collections.sort(player02);
Collections.sort(player03); /*
5.看牌
调用看牌的方法
*/ lookPoker("刘德华",map,player01);
lookPoker("周润发",map,player02);
lookPoker("周星驰",map,player03);
lookPoker("底牌",map,dipai); } /*
定义一个看牌的方法,提高代码的复用性
参数:
String name:玩家名称
HashMap<Integer,String> poker:存储牌的poker集合
ArrayList<Integer> list:存储玩家和底牌的List集合
查表法:
遍历玩家或者底牌集合,获取牌的索引
使用牌的索引,去Map集合中,找到对应的牌
*/
public static void lookPoker(String name,HashMap<Integer,String> map,ArrayList<Integer> list){
//输出玩家名称,不换行
System.out.print(name+": ");
//遍历玩家或者底牌集合,获取牌的索引
for (Integer key : list) {
//使用牌的索引,去Map集合中,找到对应的牌
String value = map.get(key);
System.out.print(value+" ");
}
System.out.println();//打印完每一个玩家的牌,换行
}
}

最新文章

  1. gg
  2. sql 语句纵表变横表
  3. 当struts遇上json,没爱了
  4. [Android] HttpURLConnection &amp; HttpClient &amp; Socket
  5. STM32学习笔记(九) 外部中断,待机模式和事件唤醒
  6. 解决mysqldump: Got error: 1044: Access denied for user
  7. 【JAVA、C++】LeetCode 020 Valid Parentheses
  8. juniper-cisco-HP上网设置
  9. 函数式编程之block
  10. Request 接收参数乱码原理解析
  11. WAMP 403 Forbidden禁止访问 的解决办法
  12. 【HDOJ】1362 The Bermuda Triangle
  13. HTML+CSS学习笔记 (6) - 开始学习CSS
  14. 解决DB2事物日志满、扩充表字段长度和表空间的命令
  15. MAC安裝《Genymotion Android模擬器》大玩Android APP (神魔之塔)
  16. Java 8 lambda初试
  17. bind、apply与call
  18. C语言成语设计第一次作业
  19. hexo 建站参考
  20. java testng框架的windows自动化-自动运行testng程序上篇

热门文章

  1. 【Java虚拟机2】Java类加载机制
  2. 【UE4 C++】定时器 Timer 与事件绑定
  3. MySQL:提高笔记-1
  4. 2021.9.12考试总结[NOIP模拟51]
  5. 洛谷 P4555 [国家集训队]最长双回文串
  6. jdk8下载与安装教程
  7. 重建二叉树 牛客网 剑指Offer
  8. java性能优化常用工具jmap、jstack
  9. httprunner3源码解读(1)简单介绍源码模块内容
  10. Spring Cloud Gateway实战之二:更多路由配置方式