亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java集合模擬實(shí)現(xiàn)斗地主洗牌和發(fā)牌

 更新時(shí)間:2021年09月26日 16:04:16   作者:upupxi  
這篇文章主要為大家詳細(xì)介紹了java集合模擬實(shí)現(xiàn)斗地主洗牌和發(fā)牌,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了java實(shí)現(xiàn)斗地主洗牌和發(fā)牌的具體代碼,供大家參考,具體內(nèi)容如下

1:用ArrayList集合實(shí)現(xiàn)

案例分析:

我們現(xiàn)在要做的是模擬斗地主小游戲來進(jìn)行洗牌和發(fā)牌。

具體步驟:

A:首先,創(chuàng)建一個(gè)ArrayList集合來存儲牌,將牌的花色和點(diǎn)數(shù)存儲在倆個(gè)字符串?dāng)?shù)組中中,然后用for循環(huán)加強(qiáng)遍歷將每張牌的花色點(diǎn)數(shù)及大王小王存儲在集合中。
B:進(jìn)行洗牌,調(diào)用collectionas的shuffle方法。
C:進(jìn)行發(fā)牌,創(chuàng)建四個(gè)ArrayList集合,分別用來存儲玩家一,玩家二,玩家三,和底牌對應(yīng)發(fā)到手上的牌。然后用for循環(huán)遍歷這幅撲克牌用If語句判斷,然后發(fā)牌。
D:創(chuàng)建一個(gè)看牌的方法,調(diào)用即可。

具體代碼:

package com.study_01;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/*
 * 模擬斗地主洗牌和發(fā)牌
 * 分析步驟:
 * 1:創(chuàng)建一個(gè)集合來存儲牌
 * 2:洗牌
 * 3:發(fā)牌
 * 4:看牌
 * 
 */
public class Poker1 {
    public static void main(String[] args) {
        //創(chuàng)建一個(gè)集合來存牌
        ArrayList <String> Pokers=new ArrayList<>();
        String[] colors={"♠","♥","♦","♣"};
        String[] numbers={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
        for(String color:colors){
            for(String number:numbers){
                Pokers.add(color+number);   
            }
            Pokers.add("大王");
            Pokers.add("小王");
        }//洗牌
        Collections.shuffle(Pokers);
        //發(fā)牌
        /*創(chuàng)建四個(gè)集合來存儲
         * 1:張三
         * 2:李四
         * 3:王麻
         * 4:底牌
         */
        ArrayList<String> Zhangsan=new ArrayList<>();
        ArrayList<String> Lisi=new ArrayList<>();
        ArrayList<String> Wangma=new ArrayList<>();
        ArrayList<String> Dipai=new ArrayList<>();
        for(int i=0;i<Pokers.size();i++){
            if(i>=Pokers.size()-3){
                Dipai.add(Pokers.get(i));
            }else if(i%3==0){
                Zhangsan.add(Pokers.get(i));
            }else if(i%3==1){
                Lisi.add(Pokers.get(i));
            }else if(i%3==2){
                Wangma.add(Pokers.get(i));
            }
        }//看牌
        lookPokers("張三",Zhangsan);
        lookPokers("李四",Lisi);
        lookPokers("王麻",Wangma);
        lookPokers("底牌",Dipai);     
    }
    private static void lookPokers(String name, ArrayList<String> Pokers){
        System.out.println(name+"的牌是:");
        for(String poker:Pokers){
            System.out.print(poker+" ");
        }System.out.println();  
    }
    }

運(yùn)行結(jié)果:

2:用TreeMap集合實(shí)現(xiàn)

具體步驟:

A:創(chuàng)建TreeMap集合存儲牌,并且大的鍵對應(yīng)大的牌,小的鍵對應(yīng)小的牌,同上創(chuàng)建倆個(gè)數(shù)組,一個(gè)用來存儲花色,一個(gè)用來存儲點(diǎn)數(shù),另外創(chuàng)建一個(gè)ArrayList集合,用來存儲沒有任意一張牌對應(yīng)的索引。
B:.洗牌,洗的是索引(map集合中每一張牌對應(yīng)的鍵),我們這里用的是ArrayList來存儲。
C:發(fā)牌,發(fā)的索引,并且對這個(gè)索引進(jìn)行排序,這是利用了TreeSet的有序性。
D:看牌,根據(jù)發(fā)到的索引去map集合中找出對應(yīng)的值。

具體代碼:

package com.study_01;
import java.util.ArrayList;
import java.util.Collections;
import java.util.TreeMap;
import java.util.TreeSet;
/**
 * 1.創(chuàng)建Map集合存儲牌,并且大的鍵對應(yīng)大的牌,小的鍵對應(yīng)小的牌
 * 2.洗牌,洗的是索引(map集合中每一張牌對應(yīng)的鍵)
 * 3.發(fā)牌,發(fā)的索引,并且歲這個(gè)索引進(jìn)行排序
 * 4.看牌,根據(jù)發(fā)到的鍵去map集合中找出對應(yīng)的值
 */
public class Poker2 {
    public static void main(String[] args) {
        //創(chuàng)建一個(gè)TreeMap集合
        TreeMap<Integer,String> Pokers=new TreeMap<>();
        String[] colors={"♥","♠","♦","♣"};
        String[] numbers={"3","4","5","6","7","8","9","10","J","Q","K","A","2",};
        //創(chuàng)建一個(gè)ArrayList集合,用來存儲沒有一張牌對應(yīng)的索引
        ArrayList<Integer> indexs=new ArrayList<>();
        int index = 0;
        for(String color:colors){
            for(String number:numbers){
                Pokers.put(index, color+number);
                indexs.add(index);
                index++;    
            }//存大王,小王
            Pokers.put(index, "大王");
            indexs.add(index);
            index++;
            Pokers.put(index, "小王");
            indexs.add(index);
            index++;
        }//洗牌,洗的是索引(map集合中每一張牌對應(yīng)的鍵)
        Collections.shuffle(indexs);
        //發(fā)牌,發(fā)的是索引根據(jù)索引來找它對應(yīng)的值
        TreeSet<Integer> zhangsan=new TreeSet<>();
        TreeSet<Integer> lisi=new TreeSet<>();
        TreeSet<Integer> wangma=new TreeSet<>();
        TreeSet<Integer> dipai=new  TreeSet<>();
        for(int i=0;i<Pokers.size();i++){
            if(i>=Pokers.size()-3){
                dipai.add(indexs.get(i));
            }else if(i%3==0){
                zhangsan.add(indexs.get(i));
            }else if(i%3==1){
                lisi.add(indexs.get(i));
            }else if(i%3==2){
                wangma.add(indexs.get(i));
            }
        }//看牌
        lookPoker("張三",zhangsan,Pokers);
        lookPoker("李四",lisi,Pokers);
        lookPoker("王麻",wangma,Pokers);
        lookPoker("底牌",dipai,Pokers);   
    }
    private static void lookPoker(String name, TreeSet<Integer> indexs,
            TreeMap<Integer, String> Pokers) {
        System.out.println(name+"的牌是:");
        for(Integer index:indexs){
            System.out.print(Pokers.get(index));
        }System.out.println();
    }
}

運(yùn)行結(jié)果:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Java方法配置Spring代碼解析

    使用Java方法配置Spring代碼解析

    這篇文章主要介紹了使用Java方法配置Spring代碼解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • java爬蟲Gecco工具抓取新聞實(shí)例

    java爬蟲Gecco工具抓取新聞實(shí)例

    本篇文章主要介紹了JAVA 爬蟲Gecco工具抓取新聞實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2016-10-10
  • java設(shè)計(jì)模式筆記之裝飾模式

    java設(shè)計(jì)模式筆記之裝飾模式

    這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)模式筆記之裝飾模式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • 一文詳解Spring是怎么讀取配置Xml文件的

    一文詳解Spring是怎么讀取配置Xml文件的

    這篇文章主要介紹了一文詳解Spring是怎么讀取配置Xml文件的,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-08-08
  • 配置了jdk的環(huán)境idea卻提示找不到j(luò)dk解決辦法

    配置了jdk的環(huán)境idea卻提示找不到j(luò)dk解決辦法

    在使用Java編程語言進(jìn)行開發(fā)時(shí),IDEA是一個(gè)非常流行和強(qiáng)大的集成開發(fā)環(huán)境,這篇文章主要給大家介紹了關(guān)于配置了jdk的環(huán)境idea卻提示找不到j(luò)dk的解決辦法,需要的朋友可以參考下
    2023-12-12
  • JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹

    JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹

    這篇文章主要為大家介紹了JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Java中 ? extends T 和 ? super T的理解

    Java中 ? extends T 和 ? super&nb

    本文主要介紹了Java中 ? extends T 和 ? super T的理解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 使用bitset實(shí)現(xiàn)毫秒級查詢(實(shí)例講解)

    使用bitset實(shí)現(xiàn)毫秒級查詢(實(shí)例講解)

    下面小編就為大家?guī)硪黄褂胋itset實(shí)現(xiàn)毫秒級查詢(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • 基于Calendar獲取當(dāng)前時(shí)間的性能比較

    基于Calendar獲取當(dāng)前時(shí)間的性能比較

    這篇文章主要介紹了Calendar獲取當(dāng)前時(shí)間的性能比較,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面

    Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面

    這篇文章主要介紹了Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評論