模拟斗地主洗牌和发牌并且排序

思路:

在这里插入图片描述
在这里插入图片描述

public class test {
	//写一个方法看牌
	public static void lookup(String name,TreeSet<Integer> ts,HashMap<Integer,String> hm){
		System.out.print(name+"的牌是:");
		for(Integer key:ts){
			String value=hm.get(key);
			System.out.print(value+" ");
		}
		System.out.println();
	}
	public static void lookup(String name,ArrayList<String> s){
		System.out.print(name+"的牌是:");
		for(String ss:s){
			System.out.print(ss+" ");
		}
		System.out.println();
	}
	public static void main(String[] args) {
		//创建一个HashMap集合
		HashMap<Integer,String> hm=new HashMap<Integer,String>();
		
		//创建一个ArrayList集合
		ArrayList<Integer> array=new ArrayList<Integer>();
		//创建花色数组
		String[] colors={"♠","♥","♣","◆"};
		//定义一个点数组
		String[] numbers={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
		
		//从0开始往HashMap里面存储编号,并存储对应的牌,同时往ArrayList里面存储编号即可。
		int index=0;
		for(String s:numbers){
			for(String c:colors){
				String poker=c.concat(s);
				hm.put(index, poker);
				array.add(index);
				index++;
			}
		}
		hm.put(index, "小王");
		array.add(index);
		index++;
		hm.put(index, "大王");
		array.add(index);
		
		//洗牌(洗的是编号)
		Collections.shuffle(array);
		
		//发牌,发的是编号,为了保证编号的唯一性,就创建TreeSet集合接收
		TreeSet<Integer> player1=new TreeSet<Integer>();
		TreeSet<Integer> player2=new TreeSet<Integer>();
		TreeSet<Integer> player3=new TreeSet<Integer>();
		TreeSet<Integer> dipai=new TreeSet<Integer>();
		for(int x=0;x<array.size();x++){
			if(x>=array.size()-3){
				dipai.add(array.get(x));
			}else if(x%3==0){
				player1.add(array.get(x));
			}else if(x%3==1){
				player2.add(array.get(x));
			}else if(x%3==2){
				player3.add(array.get(x));
			}
		}
		
		//看牌(遍历TreeSet集合,获取编号,到HashMap集合找到对应的牌)
		lookup("张三",player1,hm);
		lookup("李四",player2,hm);
		lookup("王五",player3,hm);
		lookup("底牌",dipai,hm);
		
	}
	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java后端指南

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值