您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何用Java寫一個(gè)斗地主”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“如何用Java寫一個(gè)斗地主”吧!
1.創(chuàng)建HashMap,鍵是編號(hào),值是牌。
2.創(chuàng)建ArrayList,存儲(chǔ)編號(hào)。
3.創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組。
4.從0開(kāi)始往HashMap里面存儲(chǔ)編號(hào),并存儲(chǔ)對(duì)應(yīng)的牌。同時(shí)往ArrayList里面存儲(chǔ)編號(hào)。
5.洗牌(洗的是編號(hào)),用Collections的shuffl()方法實(shí)現(xiàn)。
6.發(fā)牌(發(fā)的也是編號(hào),為了保證編號(hào)是排序的,創(chuàng)建TreeSet集合。
7.定義方法看牌(遍歷TreeSet集合,獲取編號(hào),到HashMap集合找對(duì)應(yīng)的牌)
8.調(diào)用看牌方法
//創(chuàng)建HashMap集合 key是編號(hào)用Integer value是牌用String
HashMap<Integer,String> hm=new HashMap<>();
//創(chuàng)建ArrayList集合用來(lái)存儲(chǔ)編號(hào)
ArrayList<Integer> list=new ArrayList<>();
//創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組
String [] color={"?", "?", "?","?"};
String [] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
//從0開(kāi)始往HashMap集合里面存儲(chǔ)編號(hào),并存儲(chǔ)對(duì)應(yīng)的牌。同時(shí)往ArrayList集合里面存儲(chǔ)編號(hào)
int index=0;
//增強(qiáng)For循環(huán)存儲(chǔ)花色和點(diǎn)數(shù)
for(String num:number){
for(String col:color){
hm.put(index,col+num);
list.add(index);
index++;
}
}
//52張牌存完了 還剩大小王 現(xiàn)在添加進(jìn)去
hm.put(index,"小王");
list.add(index);
index++;
hm.put(index,"大王");
list.add(index);
//以上的操作實(shí)現(xiàn)了把54張撲克牌放入一個(gè)集合容器。
//洗牌(洗的是編號(hào)),用collections的shuffle()方法實(shí)現(xiàn)。
Collections.shuffle(list);
//發(fā)牌 用TreeSet接收 用三位玩家名字命名
TreeSet<Integer> PDD=new TreeSet<>();
TreeSet<Integer> DaSiMa=new TreeSet<>();
TreeSet<Integer> LuBenWei=new TreeSet<>();
//三張底牌
TreeSet<Integer> finalCard=new TreeSet<>();
for(int x=0;x<list.size();x++){
//定義一個(gè)變量接收索引
int a= list.get(x);
//最后三個(gè)索引
if(x>=list.size()-3){
finalCard.add(a);
}else if(x%3 == 0){
PDD.add(a);
}else if(x%3 == 1){
DaSiMa.add(a);
}else {
LuBenWei.add(a);
}
}
//定義看牌的方法(遍歷TreeSet集合,獲取編號(hào),到HashMap集合找對(duì)應(yīng)的牌)
public static void lookPoker(String name,TreeSet<Integer> ts,HashMap<Integer,String> hm ){
System.out.print(name+"的手牌為:");
//遍歷牌 就是遍歷索引
for(Integer key:ts){
String poker = hm.get(key);
System.out.print(poker+" ");
}
System.out.println();
}
package 模擬斗地主;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.TreeSet;
/*需求:
通過(guò)程序?qū)崿F(xiàn) 斗地主過(guò)程中的洗牌,發(fā)牌和看牌功能,并且為了方便看牌手牌要排序。
思路:
1:創(chuàng)建HashMap集合,鍵是編號(hào),值是牌。
2:創(chuàng)建Arraylist集合用于存儲(chǔ)編號(hào)。
3:創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組。
4:從0開(kāi)始往HashMap集合里面存儲(chǔ)編號(hào),并存儲(chǔ)對(duì)應(yīng)的牌。同時(shí)往ArrayList集合里面存儲(chǔ)編號(hào)。
5 :洗牌(洗的是編號(hào)),用collections的shuffle()方法實(shí)現(xiàn)。
6:發(fā)牌(發(fā)的也是編號(hào),為了保證編號(hào)是排序的,創(chuàng)建TreeSet集合接收
7:定義方法看牌(遍歷TreeSet集合,獲取編號(hào),到HashMap集合找對(duì)應(yīng)的牌)
8:調(diào)用方法看牌
*/
public class ChinesePoker {
public static void main(String[] args) {
//創(chuàng)建HashMap集合 key是編號(hào)用Integer value是牌用String
HashMap<Integer,String> hm=new HashMap<>();
//創(chuàng)建ArrayList集合用來(lái)存儲(chǔ)編號(hào)
ArrayList<Integer> list=new ArrayList<>();
//創(chuàng)建花色數(shù)組和點(diǎn)數(shù)數(shù)組
String [] color={"?", "?", "?","?"};
String [] number={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
//從0開(kāi)始往HashMap集合里面存儲(chǔ)編號(hào),并存儲(chǔ)對(duì)應(yīng)的牌。同時(shí)往ArrayList集合里面存儲(chǔ)編號(hào)
int index=0;
//增強(qiáng)For循環(huán)存儲(chǔ)花色和點(diǎn)數(shù)
for(String num:number){
for(String col:color){
hm.put(index,col+num);
list.add(index);
index++;
}
}
//52張牌存完了 還剩大小王 現(xiàn)在添加進(jìn)去
hm.put(index,"小王");
list.add(index);
index++;
hm.put(index,"大王");
list.add(index);
//洗牌(洗的是編號(hào)),用collections的shuffle()方法實(shí)現(xiàn)。
Collections.shuffle(list);
//發(fā)牌 用TreeSet接收 用三位玩家名字命名
TreeSet<Integer> PDD=new TreeSet<>();
TreeSet<Integer> DaSiMa=new TreeSet<>();
TreeSet<Integer> LuBenWei=new TreeSet<>();
//三張底牌
TreeSet<Integer> finalCard=new TreeSet<>();
for(int x=0;x<list.size();x++){
//定義一個(gè)變量接收索引
int a= list.get(x);
//最后三個(gè)索引
if(x>=list.size()-3){
finalCard.add(a);
}else if(x%3 == 0){
PDD.add(a);
}else if(x%3 == 1){
DaSiMa.add(a);
}else {
LuBenWei.add(a);
}
}
//調(diào)用看牌方法
lookPoker("PDD",PDD,hm);
lookPoker("大司馬",DaSiMa,hm);
lookPoker("盧本偉",LuBenWei,hm);
lookPoker("底牌",finalCard,hm);
}
//定義看牌的方法(遍歷TreeSet集合,獲取編號(hào),到HashMap集合找對(duì)應(yīng)的牌)
public static void lookPoker(String name,TreeSet<Integer> ts,HashMap<Integer,String> hm ){
System.out.print(name+"的手牌為:");
//遍歷牌 就是遍歷索引
for(Integer key:ts){
String poker = hm.get(key);
System.out.print(poker+" ");
}
System.out.println();
}
}
感謝各位的閱讀,以上就是“如何用Java寫一個(gè)斗地主”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)如何用Java寫一個(gè)斗地主這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。