集合案例-模擬斗地主洗牌發(fā)牌

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.TreeSet;

/*
 * 思路:
 *      A:創(chuàng)建一個(gè)HashMap集合
 *      B:創(chuàng)建一個(gè)ArrayList集合
 *      C:創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組
 *      D:從0開始往HashMap里面存儲(chǔ)編號,并存儲(chǔ)對應(yīng)的牌
 *        同時(shí)往ArrayList里面存儲(chǔ)編號即可。
 *      E:洗牌(洗的是編號)
 *      F:發(fā)牌(發(fā)的也是編號,為了保證編號是排序的,就創(chuàng)建TreeSet集合接收)
 *      G:看牌(遍歷TreeSet集合,獲取編號,到HashMap集合找對應(yīng)的牌)
 */
public class PokerDemo {
    public static void main(String[] args) {
        // 創(chuàng)建一個(gè)HashMap集合
        HashMap<Integer, String> hm = new HashMap<Integer, String>();

        // 創(chuàng)建一個(gè)ArrayList集合
        ArrayList<Integer> array = new ArrayList<Integer>();

        // 創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組
        // 定義一個(gè)花色數(shù)組
        String[] colors = { "?", "?", "?", "?" };
        // 定義一個(gè)點(diǎn)數(shù)數(shù)組
        String[] numbers = { "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q",
                "K", "A", "2", };

        // 從0開始往HashMap里面存儲(chǔ)編號,并存儲(chǔ)對應(yīng)的牌,同時(shí)往ArrayList里面存儲(chǔ)編號即可。
        int index = 0;

        for (String number : numbers) {
            for (String color : colors) {
                String poker = color.concat(number);
                hm.put(index, poker);    //HashMap
                array.add(index);        //ArrayList
                index++;
            }
        }
        hm.put(index, "小鬼");
        array.add(index);
        index++;
        hm.put(index, "大鬼");
        array.add(index);

        // 洗牌(洗的是編號)
        Collections.shuffle(array);

        // 發(fā)牌(發(fā)的也是編號,為了保證編號是排序的,就創(chuàng)建TreeSet集合接收)
        TreeSet<Integer> jiaobuchong = new TreeSet<Integer>();
        TreeSet<Integer> jack = new TreeSet<Integer>();
        TreeSet<Integer> tom = new TreeSet<Integer>();
        TreeSet<Integer> baseAce = new TreeSet<Integer>();

        for (int x = 0; x < array.size(); x++) {
            if (x >= array.size() - 3) {
                baseAce.add(array.get(x));
            } else if (x % 3 == 0) {
                jiaobuchong.add(array.get(x));
            } else if (x % 3 == 1) {
                jack.add(array.get(x));
            } else if (x % 3 == 2) {
                tom.add(array.get(x));
            }
        }

        // 看牌(遍歷TreeSet集合,獲取編號,到HashMap集合找對應(yīng)的牌)
        lookPoker("膠布蟲", fengQingYang, hm);
        lookPoker("杰克", linQingXia, hm);
        lookPoker("湯姆", liuYi, hm);
        lookPoker("底牌", diPai, hm);
    }

    // 寫看牌的功能
    public static void lookPoker(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();
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • “第一次打開游戲請?jiān)试S“使用數(shù)據(jù)”,否則游戲無法正常運(yùn)行?!?《單機(jī)斗地主》是一款采用經(jīng)典斗地主玩法的棋牌游戲,豐...
    旬日閱讀 568評論 2 0
  • “第一次打開游戲請?jiān)试S“使用數(shù)據(jù)”,否則游戲無法正常運(yùn)行?!?史上最好玩的斗地主,沒網(wǎng)絡(luò)環(huán)境下的法寶,單機(jī)模式完全...
    反射閱讀 1,327評論 0 0
  • 零.前言 我們相信通過學(xué)習(xí)獲得重生 —— 對我們來說,七年就是一輩子。每一輩子都要至少習(xí)得一個(gè)重要的技能,進(jìn)而獲得...
    王偵閱讀 1,974評論 1 14
  • A1:回顧近一周的安排,你的時(shí)間黑洞在哪里?什么時(shí)候最容易浪費(fèi)掉你沒有意識(shí)到的時(shí)間呢? 過去一周,時(shí)間黑洞,主要在...
    羽辰在精進(jìn)閱讀 441評論 4 2
  • 愛人別看云朵了,請送別我 你為何又要數(shù)著 云一朵,云兩朵,云三朵 愛人說再見吧,請送別我 你為何又要盼歸期 春去,...
    雪雪雪雪小白閱讀 180評論 0 1

友情鏈接更多精彩內(nèi)容