Java实现斗地主简化版的方法

发布时间:2020-07-31 10:36:05 作者:小猪
来源:亿速云 阅读:164

这篇文章主要讲解了Java实现斗地主简化版的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。

package com.westos.chinesePoker;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;

/**
 *加强版的斗地主 EnhancedVersion
 *在version1.0的基础上加入扑克排序.
 * @author 虎虎
 * @version 2.0
 */
public class ChinesePokerEnhanced {

 public static void main(String[] args) {
  //0-53代表每个对应的扑克
  Map<Integer, String> map = new HashMap<Integer,String>();
  List<String> list = new ArrayList<>();
  String[] color = {"&#9829;","&#9824;","&#9827;","◆"};
  String[] num = {"A","2","3","4","5","6","7","8","9","10","J","Q","K"};
  for(String str:num) {
   for(String str1:color) {
    String poker = str1.concat(str);
    list.add(poker);
   }
  }
  list.add("♀");
  list.add("♂");
  for(int i=0;i<54;i++) {
    map.put(i, list.get(i));
   }
  Set<Integer> keyset = map.keySet();
  List<Integer> list1 = new ArrayList<>();
  for(Integer count:keyset){
   list1.add(count);
   }
  //洗牌三次
  Collections.shuffle(list1);
  Collections.shuffle(list1);
  Collections.shuffle(list1);

  Set<Integer> player01 = new TreeSet<>();
  Set<Integer> player02 = new TreeSet<>();
  Set<Integer> player03 = new TreeSet<>();
  Set<Integer> dipai = new TreeSet<>();
  //发牌
  for(int i=0;i<list1.size();i++) {
   if(i<51&&i%3 == 0) {
    player01.add(list1.get(i));
   }
   if(i<51&&i%3 == 1) {
    player02.add(list1.get(i));
   }
   if(i<51&&i%3 == 2) {
    player03.add(list1.get(i));
   }if(i>=51)
    dipai.add(list1.get(i));


  }
  //玩家一的牌
  System.out.println("玩家一:");
  for(Integer i:player01) {
   System.out.print(map.get(i)+" ");
  }
  System.out.println("\n玩家二:");
  //玩家二的牌
  for(Integer i:player02) {
   System.out.print(map.get(i)+ " ");
  }

  System.out.println("\n玩家三:");
  //玩家三的牌
  for(Integer i:player03) {
   System.out.print(map.get(i)+ " ");
  }
  System.out.println("\n底牌:");
  //玩家一的牌
  for(Integer i:dipai) {
   System.out.print(map.get(i)+ " ");
  }
 }
}

看完上述内容,是不是对Java实现斗地主简化版的方法有进一步的了解,如果还想学习更多内容,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. Java中for循环简化版介绍
  2. 用python实现斗地主分牌洗牌的方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java ava

上一篇:单例模式有哪些优点

下一篇:什么是策略模式

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》