贪吃蛇c语言链表头插法实现

时间: 2023-07-12 08:46:30 浏览: 73
链表头插法实现贪吃蛇的代码如下: ```c #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <time.h> #define ROW 20 // 行数 #define COL 40 // 列数 // 定义结构体 typedef struct node{ int x; // x坐标 int y; // y坐标 struct node *next; // 指向下一个节点 }snake, *psnake; typedef struct fruit{ int x; // x坐标 int y; // y坐标 }fruit; // 定义全局变量 int map[ROW][COL] = {0}; // 地图 psnake head = NULL; // 蛇头 fruit f; // 水果 // 初始化地图 void initmap(){ int i, j; for(i = 0; i < ROW; i++){ for(j = 0; j < COL; j++){ if(i == 0 || i == ROW - 1 || j == 0 || j == COL - 1){ map[i][j] = -1; // 地图边界 } else{ map[i][j] = 0; // 地图内部 } } } } // 打印地图 void printmap(){ system("cls"); // 清屏 int i, j; for(i = 0; i < ROW; i++){ for(j = 0; j < COL; j++){ if(map[i][j] == -1){ printf("#"); // 打印边界 } else if(map[i][j] == 0){ printf(" "); // 打印空格 } else if(map[i][j] == 1){ printf("*"); // 打印蛇 } else if(map[i][j] == 2){ printf("$"); // 打印水果 } } printf("\n"); // 换行 } } // 创建蛇 void createsnake(){ int x = ROW / 2; int y = COL / 2; psnake p = (psnake)malloc(sizeof(snake)); // 创建节点 p->x = x; // 给节点赋值 p->y = y; p->next = NULL; map[x][y] = 1; // 地图上标记蛇 head = p; // 头指针指向蛇头 } // 创建水果 void createfruit(){ srand((unsigned int)time(NULL)); // 产生随机数种子 while(1){ int x = rand() % ROW; int y = rand() % COL; if(map[x][y] == 0){ // 判断是否可以放水果 f.x = x; f.y = y; map[x][y] = 2; // 地图上标记水果 break; } } } // 判断是否吃到水果 int iseaten(){ if(head->x == f.x && head->y == f.y){ return 1; } return 0; } // 蛇移动 void movesnake(int dir){ psnake p = (psnake)malloc(sizeof(snake)); // 创建新节点 p->x = head->x; // 新节点的坐标为蛇头的坐标 p->y = head->y; p->next = head; // 新节点指向原来的蛇头 head = p; // 头指针指向新蛇头 map[head->x][head->y] = 1; // 地图上标记新蛇头 if(iseaten()){ // 判断是否吃到水果 createfruit(); // 重新创建水果 } else{ map[p->next->x][p->next->y] = 0; // 地图上删除原来的蛇尾 psnake q = head; while(q->next->next != NULL){ // 找到新蛇尾 q = q->next; } free(q->next); // 释放原来的蛇尾节点 q->next = NULL; } switch(dir){ // 移动方向 case 72: // 上 head->x--; break; case 80: // 下 head->x++; break; case 75: // 左 head->y--; break; case 77: // 右 head->y++; break; default: break; } } // 判断是否死亡 int isdead(){ if(head->x == 0 || head->x == ROW - 1 || head->y == 0 || head->y == COL - 1){ // 撞到墙壁 return 1; } psnake p = head->next; while(p != NULL){ // 撞到自己 if(head->x == p->x && head->y == p->y){ return 1; } p = p->next; } return 0; } int main(){ initmap(); // 初始化地图 createsnake(); // 创建蛇 createfruit(); // 创建水果 int dir = 77; // 初始方向为右 while(1){ printmap(); // 打印地图 if(kbhit()){ // 检测键盘输入 dir = getch(); // 获取键盘输入 } movesnake(dir); // 蛇移动 if(isdead()){ // 判断是否死亡 printf("Game Over!\n"); break; } } return 0; } ```

相关推荐

最新推荐

recommend-type

贪吃蛇C语言代码实现(难度可选)

主要为大家详细介绍了贪吃蛇C语言代码实现,游戏难度可供选择,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现贪吃蛇游戏代码

本文实例为大家分享了C语言实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下 //------------------------------------------problm区------------------------------ //①思考typedef 定义的变量如何利用fwrite...
recommend-type

C语言课程设计报告——贪吃蛇源程序.doc

C 语 言 课 程 设 计(小游戏贪吃蛇的程序设计报告) 目 录 一:概述 1:研究背景及意义 2:设计的任务与需要知识点 3:具体完成设计容 二:需求分析 1:功能需求 2:操作方法 三:总体设计 1:模块划分 2:数据结构...
recommend-type

课设报告-“贪吃蛇_C语言_链表实现”-CSDN~.docx

课设报告-“贪吃蛇_C语言_链表实现~_课设”中 兑现将课设报告另发一篇博客~
recommend-type

贪吃蛇代码-C语言-VC 6.0

贪吃蛇代码-C语言-VC 6.0 一个C语言写的简单贪吃蛇源代码
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

SPDK_NVMF_DISCOVERY_NQN是什么 有什么作用

SPDK_NVMF_DISCOVERY_NQN 是 SPDK (Storage Performance Development Kit) 中用于查询 NVMf (Non-Volatile Memory express over Fabrics) 存储设备名称的协议。NVMf 是一种基于网络的存储协议,可用于连接远程非易失性内存存储器。 SPDK_NVMF_DISCOVERY_NQN 的作用是让存储应用程序能够通过 SPDK 查询 NVMf 存储设备的名称,以便能够访问这些存储设备。通过查询 NVMf 存储设备名称,存储应用程序可以获取必要的信息,例如存储设备的IP地址、端口号、名称等,以便能
recommend-type

JSBSim Reference Manual

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