数据结构用jdk链表,队列,栈贪吃蛇代码

时间: 2023-08-15 07:40:17 浏览: 56
以下是使用 JDK 中的链表、队列和栈实现的贪吃蛇代码: ```java import java.util.*; public class SnakeGame { private int width; private int height; private LinkedList<Point> snake; private Point food; private Random random = new Random(); public SnakeGame(int width, int height) { this.width = width; this.height = height; snake = new LinkedList<>(); snake.add(new Point(width / 2, height / 2)); // 初始位置在中心 generateFood(); } public void play() { Scanner scanner = new Scanner(System.in); while (true) { printBoard(); System.out.print("请输入方向(w/a/s/d):"); String input = scanner.nextLine(); if (!move(input)) { System.out.println("游戏结束!"); break; } } scanner.close(); } private void printBoard() { for (int i = 0; i < height; i++) { for (int j = 0; j < width; j++) { Point p = new Point(j, i); if (snake.contains(p)) { System.out.print("O"); } else if (p.equals(food)) { System.out.print("*"); } else { System.out.print("."); } } System.out.println(); } } private boolean move(String direction) { // 计算新位置 Point head = snake.getFirst(); int dx = 0, dy = 0; switch (direction) { case "w": dy = -1; break; case "a": dx = -1; break; case "s": dy = 1; break; case "d": dx = 1; break; } Point newHead = new Point(head.x + dx, head.y + dy); // 判断是否合法 if (newHead.x < 0 || newHead.x >= width || newHead.y < 0 || newHead.y >= height) { return false; // 撞墙了 } if (snake.contains(newHead)) { return false; // 撞自己了 } // 移动蛇 snake.addFirst(newHead); if (newHead.equals(food)) { generateFood(); } else { snake.removeLast(); } return true; } private void generateFood() { while (true) { int x = random.nextInt(width); int y = random.nextInt(height); food = new Point(x, y); if (!snake.contains(food)) { break; } } } public static void main(String[] args) { SnakeGame game = new SnakeGame(20, 10); game.play(); } } class Point { int x, y; public Point(int x, int y) { this.x = x; this.y = y; } @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof Point)) { return false; } Point p = (Point) obj; return x == p.x && y == p.y; } @Override public int hashCode() { return Objects.hash(x, y); } } ``` 其中,`LinkedList` 用于存储蛇的身体,`Point` 表示二维坐标,`Random` 用于生成食物的位置。在 `move` 方法中,使用了栈的思想,将蛇头插入链表的头部,将蛇尾从链表的尾部删除,以实现蛇的移动。在 `generateFood` 方法中,使用了队列的思想,不断生成随机坐标,直到生成的坐标不在蛇的身体中,以实现随机生成食物的位置。

相关推荐

最新推荐

recommend-type

JDK的Parser来解析Java源代码详解

主要介绍了JDK的Parser来解析Java源代码的相关资料,需要的朋友可以参考下
recommend-type

使用指定的JDK启动IDEA的三种方法

今天小编就为大家分享一篇关于使用指定的JDK启动IDEA的三种方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
recommend-type

Apache Tomcat 8.5的安装配置 、JDK 1.8的安装

TOMCAT 8.5的服务器状态、Tomcat Web应用程序管理者、Tomcat虚拟主机管理员设置
recommend-type

JAVA JDK8 List分组的实现和用法

今天小编就为大家分享一篇关于JAVA JDK8 List分组的实现和用法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
recommend-type

Java8中使用一行代码读取文件

主要介绍了Java8中使用一行代码读取文件,要注意,本文介绍的方法不适合读取很大的文件,因为可能存在内存空间不足的问题,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。