当前位置: 首页 > news >正文

Java基础-斗地主游戏

目录

案例要求:​

实现思路:

代码:

Main启动类:

Card实体类:

Room操作类:

总结:


案例要求:

实现思路:

1构造卡牌,细节:实体类另设一个int类型变量表示大小,后面为了实现斗地主牌降序或者升序排序

2打乱卡牌的顺序和发牌

3选定大小王

4实现对牌顺序

5展示玩家的卡牌即可

代码:

Main启动类:

import java.io.IOException;
import java.util.*;
import java.util.stream.Collectors;//TIP 要<b>运行</b>代码,请按 <shortcut actionId="Run"/> 或
// 点击装订区域中的 <icon src="AllIcons.Actions.Execute"/> 图标。
public class Main {static Scanner sc = new Scanner(System.in);public static void main(String[] args) {Room room = new Room();room.start();}
}

Card实体类:

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.util.Objects;@Data
@AllArgsConstructor
@NoArgsConstructor
public class Card implements Comparable<Card> {private String number;private String color;private int size;@Overridepublic String toString() {return number + color;}@Overridepublic int compareTo(Card o) {return o.size-size;}
}

Room操作类:

import java.util.*;
import java.util.stream.Collectors;public class Room {private List<Card> list=new ArrayList<>();{String [] colors={"♥","♠","♣","♦"};String [] numbers={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};for (int i = 0; i < numbers.length; i++){for(int j = 0; j < colors.length; j++){list.add(new Card(numbers[i],colors[j],i));}}list.add(new Card("","\uD83C\uDCCF",13));list.add(new Card("","\uD83E\uDDD1",14));}Scanner sc = new Scanner(System.in);public void start(){System.out.println("洗牌前");System.out.println(list);System.out.println("洗牌后");
//        使用集合类工具打乱卡牌顺序Collections.shuffle(list);System.out.println(list);
//        发牌,三个玩家Map<String,List<Card>> players=new HashMap<>();List<Card> p1=new ArrayList<>();players.put("张三",p1);List<Card> p2=new ArrayList<>();players.put("李四",p2);List<Card> p3=new ArrayList<>();players.put("王五",p3);for(int i=0;i<list.size()-3;i++){if(i%3==0){p1.add(list.get(i));} else if (i%3==1) {p2.add(list.get(i));}else{p3.add(list.get(i));}}System.out.print("底牌是  ");for (int i = list.size()-3; i < list.size(); i++) {System.out.print(list.get(i)+" ");}System.out.println();System.out.print("玩家  ");for (String name : players.keySet()){System.out.print(name+" ");}System.out.print("请决定谁是地主(姓名)");String name=sc.next();for(Map.Entry<String,List<Card>> entry:players.entrySet()) {if (entry.getKey().equals(name)) {List<Card> cards = entry.getValue();cards.addAll(list.stream().skip(51).toList());}}
////TODO或者
//            if(entry.getKey().equals(name)){
//                entry.getValue().addAll(list.stream().skip(51).collect(Collectors.toList()));
//            }//        对拍顺序
//        TODO法一
//            sortCards(p1);
//            sortCards(p2);
//            sortCards(p3);
//        TODO法二Collections.sort(p1);Collections.sort(p2);Collections.sort(p3);//        看牌
/*  //TODO遍历方法一:
List<String> names=players.entrySet().stream().map(Map.Entry::getKey).toList();for(int i=0;i<names.size();i++){System.out.println(names.get(i)+"的牌是:");List<Card> cards=players.get(names.get(i));for(int j=0;j<cards.size();j++){System.out.print(cards.get(j)+"  ");}System.out.println();}*/for(Map.Entry entry:players.entrySet()){System.out.println(entry.getKey()+"的牌是:");List<Card> cards=(List<Card>) entry.getValue();for(Card card:cards){System.out.print(card+" ");}System.out.println();}}//TODO法一;哪用哪里构造比较器
//    private void sortCards(List<Card> p1) {
//        Collections.sort(p1, new Comparator<Card>() {
//            @Override
//            public int compare(Card o1, Card o2) {
//
//                return o1.getSize()-o2.getSize();
//            }
//        });
//    }////    TODO简化版的
//    private void sortCards(List<Card> p1) {
//        Collections.sort(p1, (o1, o2) -> o1.getSize()-o2.getSize());
//    }
}


总结:

本文展示了一个Java实现的简单扑克牌游戏程序。程序主要包含三个类:Main启动类、Card实体类(使用Lombok简化代码)和Room操作类。程序实现了洗牌、发牌、选择地主、排序牌面和显示牌面等功能。通过Collections工具类实现洗牌和排序,使用HashMap存储玩家信息,并展示了多种遍历和排序的实现方式(包括Lambda表达式)。程序能正确处理54张牌(含大小王),支持3名玩家游戏,由用户指定地主并获得底牌。

http://www.xdnf.cn/news/1242865.html

相关文章:

  • opencv引入libavif
  • 从 0 到 1 开发图书管理系统:飞算 JavaAI 让技术落地更简单
  • Prometheus-3--Prometheus是怎么抓取Java应用,Redis中间件,服务器环境的指标的?
  • 【慕伏白】Android Studio 配置国内镜像源
  • 内联函数:提升效率的空间换时间艺术
  • FreeRTOS源码分析四:时钟中断处理响应流程
  • 深入浅出 RabbitMQ:工作队列实战(轮训策略VS公平策略)
  • 鸿蒙南向开发 编写一个简单子系统
  • 机器学习 入门——决策树分类
  • 并发编程常用工具类(下):CyclicBarrier 与 Phaser 的协同应用
  • C++入门自学Day6-- C++模版
  • 飞算JavaAI需求转SpringBoot项目沉浸式体验
  • 【BUUCTF系列】[极客大挑战 2019]LoveSQL 1
  • vllm启动Qwen/Qwen3-Coder-30B-A3B-Instruct并支持工具调用
  • MLIR Introduction
  • android内存作假通杀补丁(4GB作假8GB)
  • History 模式 vs Hash 模式:Vue Router 技术决策因素详解
  • ZYNQ-按键消抖
  • JavaScript 中的流程控制语句详解
  • 3.JVM,JRE和JDK的关系是什么
  • 第二十四天(数据结构:栈和队列)队列实践请看下一篇
  • SQL注入SQLi-LABS 靶场less39-50详细通关攻略
  • 基于实时音视频技术的远程控制传输SDK的功能设计
  • 【ECCV2024】AdaCLIP:基于混合可学习提示适配 CLIP 的零样本异常检测
  • [GESP202306 四级] 2023年6月GESP C++四级上机题超详细题解,附带讲解视频!
  • 刷题记录0804
  • ref和reactive的区别
  • 8位以及32位的MCU如何进行选择?
  • ArrayDeque双端队列--底层原理可视化
  • Redis 常用数据结构以及单线程模型