码迷,mamicode.com
首页 > 编程语言 > 详细

Java集合练习:斗地主游戏

时间:2015-12-02 12:42:52      阅读:312      评论:0      收藏:0      [点我收藏+]

标签:java   案例   斗地主   

这是一个模拟斗地主的小游戏,最后看到的牌型是经过排序的,具体代码和解释如下:


package cn.poker_test;


import java.util.ArrayList;

import java.util.Collections;

import java.util.HashMap;

import java.util.TreeSet;

/*

 * 模拟斗地主小游戏

 * 

 * 思路:

 * A:创建一个HashMap集合

 * B:创建一个ArrayList集合

 * C:创建花色数组和点数数组

 * D:从0开始往HashMap里面存储编号,并存储对应的牌

 * 同时往ArrayList里面存储编号即可

 * E:洗牌(洗的是编号)

 * F:发牌(发的也是编号,为了保证编号是排序的,就创建TreeSet集合接收)

 * G:看牌(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)

 */

public class PokerGameDemo {

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 number : numbers) {

for(String color : colors) {

String poker = color.concat(number);

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> zhangXiaoQi = new TreeSet<Integer>();

TreeSet<Integer> meiChangSu = new TreeSet<Integer>();

TreeSet<Integer> linQingXia = new TreeSet<Integer>();

TreeSet<Integer> diPai = new TreeSet<Integer>();

for(int x=0;x<array.size();x++) {

if(x>array.size()-4) {

diPai.add(array.get(x));

} else if(x%3==0) {

zhangBingWei.add(array.get(x));

} else if(x%3==1) {

meiChangSu.add(array.get(x));

} else if(x%3==2) {

linQingXia.add(array.get(x));

}

}

//看牌(遍历TreeSet集合,获取编号,到HashMap集合找对应的牌)

lookPoker("张小七",zhangBingWei,hm);

lookPoker("梅长苏",meiChangSu,hm);

lookPoker("林青霞",linQingXia,hm);

lookPoker("底牌",diPai,hm);

}

public static void lookPoker(String name, TreeSet<Integer> ts, HashMap<Integer, String> hm) {

System.out.print(name+"的牌是:");

for(int key : ts) {

String value = hm.get(key);

System.out.print(value+" ");

}

System.out.println();

}

}

运行结果:

张小七的牌是:3 4 6 6 8 9 10 J Q K K A 2 2 2 小王 大王 

梅长苏的牌是:3 4 5 5 5 6 8 9 9 10 J Q Q K A A 2 

林青霞的牌是:3 3 4 4 5 6 7 7 8 9 10 10 J J Q K A 

底牌的牌是:7 7 8 


本文出自 “爱网络-爱生活” 博客,请务必保留此出处http://18071480160.blog.51cto.com/5230907/1718758

Java集合练习:斗地主游戏

标签:java   案例   斗地主   

原文地址:http://18071480160.blog.51cto.com/5230907/1718758

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!