当前位置: 首页 > 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.dtcms.com/a/314232.html

相关文章:

  • ArrayDeque双端队列--底层原理可视化
  • ubuntu修改时区
  • 【HZ-T536开发板免费体验】Cangjie Magic调用视觉语言大模型(VLM)真香,是不是可以没有YOLO和OCR了?
  • 通用 PDF 文件流 OCR 到文本 API 接口
  • 使用 Aspose.OCR 将图像文本转换为可编辑文本
  • 基础14-Java集合框架:掌握List、Set和Map的使用
  • 十字滑台:精密制造的“心脏“如何跳动?
  • 耘瞳科技国产化点云处理软件,开启智能化三维测量新时代
  • [机器学习]01-构建简单的贝叶斯分类器
  • 抓包相关知识学习
  • 项目复盘:Arena Of Furnace
  • vtkSSAAPass代码解析
  • [自动化Adapt] 回放策略 | AI模型驱动程序
  • Python异常捕获全指南
  • 智慧泵房赋能二次供水互联网化:物联网驱动下的全场景解决方案
  • Solidity全局变量与安全实践指南
  • Linux 文件与目录属性管理总结
  • 设备能力指标(CP/CPK)
  • C盘空间清理
  • JVM学习日记(十六)Day16——性能监控与调优(三)
  • AgxOrin平台JetPack5.x版本fix multi-cam race condition 补丁
  • 【Conda】常用指令操作
  • 机器学习——决策树(DecisionTree)+ 过采样 + 交叉验证 案例:电信客户流失数据
  • VAE学习笔记
  • Linux 网络深度剖析:传输层协议 UDP/TCP 原理详解
  • 【STM32】GPIO的输入输出
  • 正点原子STM32MP257开发板移植ubuntu24.04根文件系统(带桌面版)
  • Android的UI View是如何最终绘制成一帧显示在手机屏幕上?
  • Android Espresso 测试框架深度解析:从入门到精通
  • imx6ull-驱动开发篇8——设备树常用 OF 操作函数