练习---斗地主案例分析和代码实现
练习---斗地主案例分析
按照斗地主的规则,完成洗牌发牌的动作。具体规则:
使用54张牌打乱顺序,三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌。
练习---斗地主案例代码实现
public static void main(String[] args) { //1.准备牌 //定义一个存储54张牌的ArrayList集合,泛型使用string ArrayList<String> poker = new ArrayList<>(); //定义两个数组,一个数组存储牌的花色,一个数组存储牌的序号 String[] colors = {"♠", "❤", "♣", "◆"}; String[] numbers = {"2", "A", "K", "Q", "J", "10", "9", "8", "7", "6", "5", "4", "3"}; //先把大王和小王存储到poker集合中 poker.add("大王"); poker.add("小王"); //循环嵌套遍历两个数组,组装52张牌 for (String number : numbers) { for (String color : colors) { //System.out.println(color + number); // 把组装好的牌存储到poker集合中 poker.add(color + number); } } // System.out.println(poker); /* 2.洗牌 使用集合的工具类collections中的方法 static void shuffle(list<?> list)使用黑f认随机源对指定列表进行置换。 */ Collections.shuffle(poker); // System.out.printLn( poker); /* 3.发牌 */ //定义4个集合,存储玩家的牌和底牌 ArrayList<String> player01 = new ArrayList<>(); ArrayList<String> player02 = new ArrayList<>(); ArrayList<String> player03 = new ArrayList<>(); ArrayList<String> dipai = new ArrayList<>(); /* 遍历poker集合,获取每一张牌 使用poker集合的索引%3给3个玩家轮流发牌剩余3张牌给底牌 注意: 先判断底牌(i>=51 ),否则牌就发没了 */ for (int i = 0; i < poker.size() ; i++){ //获取每一张牌 String p = poker.get(i ) ;//轮流发牌 if(i>=51){ //给底牌发牌 dipai.add(p); }else if(i%3==0){ //给玩家1发牌 player01.add(p); }else if(i%3==1){ //给玩家2发牌 player02.add(p); }else if(i%3==2){ //给玩家3发牌 player03.add(p); } } //看牌 System.out.println("刘德华"+player01); System.out.println("周润发"+player02); System.out.println("周星驰"+player03); System.out.println("底牌"+dipai); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix