C++ 一个有bug的贪吃蛇。。。。。。。。

C++    一个有bug的贪吃蛇。。。。。。。。

#include <graphics.h>
#include<Windows.h>
#include<Mmsystem.h>
#include<conio.h> 
#include<time.h> 
#include<stdio.h>
#include<easyx.h>
using namespace std;
#pragma warning(disable:4996)
#define WINDOW_LENGTH 640 //窗口长
#define WINDOW_WIDE 480 //串口宽
#define M_TOP 50 //地图左上顶点y坐标
#define M_LEFT 20 //地图左上顶点x坐标
#define M_BOTTOM WINDOW_WIDE-30 //地图右下顶点y坐标
#define M_RIGHT WINDOW_LENGTH-30 //地图右下顶点x坐标
#define SNAKE_UP 72 //蛇向上运动
#define SNAKE_DOWN 80 //蛇向下运动
#define SNAKE_LEFT 75 //蛇向左运动
#define SNAKE_RIGHT 77  //蛇向右运动
#define SNAKE_QUIT 27 //结束游戏ESC键
#define SNAKE_SPEED 500 //蛇运动速度
#define SNAKE_PAUSS 32 //蛇暂停运动


typedef struct FOOD { //定义食物结构体
	int x;
	int y;
	int FOOD_LIVE;
}FOOD;


typedef struct NODE { //定义蛇的节点
	int x;
	int y;
	NODE* PRE;
	NODE* NEXT;
}NODE;


typedef struct SANKE { //定义一个蛇
	NODE* TAIL;
	NODE* HEAD;
	int NODES; //蛇的节数
	int DIRECTION; //蛇的运动方向
	int SANKE_LIVE; //存活状态
}SANKE;


int score_ = 0;
FOOD f;
SANKE s;
int rank;
int t = 1;
int tt;
int biteSelf(); // 判断是否咬到了自己
int snake_life(); //蛇是否存活
void gameover(); //结束界面
int eatfood(); /食物
void score(); //分数
void time(); //时间
void meau(); //菜单
void initGAME(); //初始化游戏
void creatWINDOW(int x, int y); //创建窗口
void closeWINDOW(); //关闭窗口
void creatmap(); //创建地图
void creatfood(); //创建食物
void drawfood(); //画食物
void drawSANKE(); //画蛇
void initSANKE(); //创建蛇
void moveSANKE(); //移动蛇
void speed(); //调整速度
void playgame(); //开始游戏
int direction(int c); //判断操作方向是否与蛇的方向相同
void Data(); //保存分数
void ESC(); //esc结束
void upgrade(); //升级模式




int main()
{
	while (t)
	{
		meau();
		initGAME();
		playgame();
		closeWINDOW();
	}
}


void initGAME()//进入游戏
{
	creatWINDOW(WINDOW_LENGTH, WINDOW_WIDE);
	creatmap();
	creatfood();
	initSANKE();
	score();
	f.FOOD_LIVE = 0;
}


void creatWINDOW(int x, int y) {//创建窗口
	initgraph(WINDOW_LENGTH, WINDOW_WIDE);
	setbkcolor(RGB(166, 135, 100));
	cleardevice();
}


void closeWINDOW() {//关闭窗口
	Data();
	getch();
	closegraph();
}


void creatmap() {
	int i;
	setlinecolor(BLACK);
	rectangle(M_LEFT, M_TOP, M_RIGHT, M_BOTTOM);//画外边界线
	rectangle(M_LEFT - 10, M_TOP - 10, M_RIGHT + 10, M_BOTTOM + 10);//画内边界线
	for (i = M_LEFT; i <= M_RIGHT; i = i + 10)
		line(i, M_TOP, i, M_TOP - 10);
	for (i = M_TOP; i <= M_BOTTOM; i = i + 10)
		line(M_LEFT, i, M_LEFT - 10, i);
	for (i = M_LEFT; i <= M_RIGHT; i = i + 10)
		line(i, M_BOTTOM, i, M_BOTTOM + 10);
	for (i = M_TOP; i <= M_BOTTOM; i = i + 10)
		line(M_RIGHT, i, M_RIGHT + 10, i);
}


void creatfood() {
	srand(time(0));
	int x, y;
	while (1) {
		x = rand() % (600 - 20 + 1) + 20;
		y = rand() % (440 - 50 + 1) + 50;
		if (x % 10 == 0 && y % 10 == 0) {
			f.x = x;
			f.y = y;
			break;
		}
	}
	f.FOOD_LIVE = 1;
}


void drawfood() {
	setfillcolor(YELLOW);
	fillrectangle(f.x, f.y, f.x + 9, f.y + 9);
}


void initSANKE() {
	s.HEAD = (NODE*)malloc(sizeof(NODE));
	s.TAIL = (NODE*)malloc(sizeof(NODE));
	s.HEAD->x = 30;//初始蛇头蛇尾
	s.HEAD->y = 400;
	s.TAIL->x = 30;
	s.TAIL->y = 410;
	s.HEAD->NEXT = s.TAIL;
	s.HEAD->PRE = NULL;
	s.TAIL->NEXT = NULL;
	s.TAIL->PRE = s.HEAD;
	s.DIRECTION = SNAKE_UP;
	s.NODES = 2;
	s.SANKE_LIVE = 1;
}


void drawSANKE() {
	NODE* p;//指针p指向蛇的头部
	p = s.HEAD;
	while (p)
	{
		if (p == s.HEAD)
			setfillcolor(BLUE);//蛇头为蓝色
		else
			setfillcolor(YELLOW);
		fillrectangle(p->x, p->y, p->x + 9, p->y + 9);
		p = p->NEXT;
	}
}


int direction(int c) {//不是相反的方向,返回0.

	if (s.DIRECTION == SNAKE_DOWN && c == SNAKE_UP)
		return 1;
	else if (s.DIRECTION == SNAKE_UP && c == SNAKE_DOWN)
		return 1;
	else if (s.DIRECTION == SNAKE_LEFT && c == SNAKE_RIGHT)
		return 1;
	else if (s.DIRECTION == SNAKE_RIGHT && c == SNAKE_LEFT)
		return 1;
	else
		return 0;
}


void playgame() {
	int c;
	while (true) {
		if (f.FOOD_LIVE == 1)//若食物存在,则画出食物
		{
			drawfood();
		}
		if (f.FOOD_LIVE == 0)//若食物不存在,则生成食物
		{
			creatfood();
			drawfood();
		}
		if (snake_life() == 0)//若蛇死亡,游戏结束
		{
			gameover();
			closeWINDOW();
			break;
		}
		while (!kbhit())//当没有按键的时候
		{
			time();
			if (eatfood() == 1)
			{
				creatfood();
				drawfood();
			}
			if (snake_life() == 0)//若蛇死亡,游戏结束
			{
				break;
			}
			moveSANKE();
			drawSANKE();
			if (tt)
				upgrade();
			speed();
		}
		while (kbhit())//当有按键的时候
		{
			c = getch();
			if (direction(c) == 0)//不是相反的方向
			{
				switch (c)
				{
				case SNAKE_LEFT: s.DIRECTION = SNAKE_LEFT; break;
				case SNAKE_RIGHT: s.DIRECTION = SNAKE_RIGHT; break;
				case SNAKE_UP: s.DIRECTION = SNAKE_UP; break;
				case SNAKE_DOWN: s.DIRECTION = SNAKE_DOWN; break;
				case SNAKE_PAUSS:system("pause"); break;
				case SNAKE_QUIT:ESC();
				default:break;
				}
			}
		}
	}
}


void ESC() {
	gameover();
	_getch();
	exit(0);
}


void moveSANKE() {
	NODE* p;
	p = (NODE*)malloc(sizeof(NODE));
	clearrectangle(s.TAIL->x, s.TAIL->y, s.TAIL->x + 9, s.TAIL->y + 9);//清楚原来的蛇尾
	creatmap();//绘制地图

	p = s.TAIL;

	while (p->PRE != NULL)
	{
		p->x = p->PRE->x;
		p->y = p->PRE->y;
		p = p->PRE;
	}

	switch (s.DIRECTION) {//蛇头变换方向
	case SNAKE_UP:s.HEAD->y -= 10; break;
	case SNAKE_LEFT:s.HEAD->x -= 10; break;
	case SNAKE_DOWN:s.HEAD->y += 10; break;
	case SNAKE_RIGHT:s.HEAD->x += 10; break;
	default:break;
	}
}


void speed() {
	Sleep(rank);
}


int snake_life() {
	int x, y;
	x = s.HEAD->x;
	y = s.HEAD->y;
	if (x < 20 || x > 600 || y > 440 || y < 50)//蛇头出界,蛇死亡
		s.SANKE_LIVE = 0;
	if (biteSelf() == 1)//蛇吃到自己蛇死亡
		s.SANKE_LIVE = 0;
	return s.SANKE_LIVE;
} //蛇是否存活


void gameover() {
	int c, x;
	x = 1;
	//musicforgg();
	settextstyle(50, 0, _T("宋体"));
	settextcolor(BLUE);
	char s1[] = "你死掉了!!!";
	outtextxy(150, 200, s1);
	_getch();
	initgraph(WINDOW_LENGTH, WINDOW_WIDE);
	setbkcolor(BLACK);
	cleardevice();
	settextcolor(YELLOW);
	char s[] = "";
	sprintf(s, "%s%d", "您的分数是:", score_);
	char s3[] = "1.重新挑战";
	char s2[] = "2.退出游戏";
	settextstyle(30, 0, _T("宋体"));
	outtextxy(200, 200, s3);
	outtextxy(200, 250, s2);
	settextstyle(50, 0, _T("宋体"));
	outtextxy(150, 100, s);

	settextcolor(WHITE);
	char s5[] = "按任意键继续。。。";
	char s7[] = "输入有误。。。";
	char s8[] = "谢谢使用!";
	while (x) {
		kbhit();
		c = getch();
		switch (c) {
		case '1':t = 1; x = 0; outtextxy(150, 350, s5);
			score_ = 0; main(); break;//继续生成游戏
		case '2':outtextxy(150, 350, s8); getch(); exit(0);//退出游戏
		default:x = 1; outtextxy(150, 350, s7); break;
		}
	}
}//结束界面

int eatfood() {
	int x1 = s.HEAD->x;
	int y1 = s.HEAD->y;
	int x2 = f.x;
	int y2 = f.y;
	NODE* p;
	if (x1 == x2 && y1 == y2)//蛇的头部和食物重叠
	{
		s.TAIL->NEXT = (NODE*)malloc(sizeof(NODE));//扩大蛇的长度
		s.TAIL->NEXT->x = s.TAIL->x;
		s.TAIL->NEXT->y = s.TAIL->y;
		s.TAIL->NEXT->PRE = s.TAIL;
		s.TAIL->NEXT->NEXT = NULL;
		p = s.TAIL->NEXT;
		s.TAIL = p;//尾部扩展
		s.NODES++;//蛇的长度+1


		f.FOOD_LIVE = 0;
		s.NODES++;
		f.x = 0 - f.x;
		score_ += 10;
		score();
		return 1;
	}
	else
		return 0;
} /食物


void score() {//记录分数
	char str[20];
	settextcolor(YELLOW);//颜色:灰色
	settextstyle(20, 0, _T("宋体"));//大小和字体
	sprintf(str, "得分:%d", score_);//生成字符串
	outtextxy(10, 20, str);
} //分数


void time() {
	char str[20];
	char c[] = "提示:空格键暂停游戏,ESC键结束游戏。";
	time_t t;
	struct tm* lt;
	settextstyle(20, 0, _T("宋体"));//大小和字体
	time(&t);//获取Unix时间戳。
	lt = localtime(&t);//转为时间结构。
	sprintf(str, "时间:%2d:%2d:%2d", lt->tm_hour, lt->tm_min, lt->tm_sec);//生成字符串
	outtextxy(500, 20, str);
	outtextxy(100, 20, c);
}//时间


void meau() {
	int c;
	int x;
	x = 1;
	initgraph(WINDOW_LENGTH, WINDOW_WIDE);
	setbkcolor(BLACK);
	cleardevice();
	settextstyle(50, 0, _T("宋体"));
	settextcolor(YELLOW);
	char s[] = "欢迎来到贪吃蛇!";
	outtextxy(170, 100, s);
	settextstyle(25, 0, _T("宋体"));
	char s1[] = "选择难度:";
	char s2[] = "1.简单模式";
	settextcolor(GREEN);
	outtextxy(250, 240, s2);
	char s3[] = "2.普通模式";
	settextcolor(BLUE);
	outtextxy(250, 280, s3);
	char s4[] = "3.困难模式";
	settextcolor(RED);
	outtextxy(250, 320, s4);
	char s7[] = "输入有误。。。";

	settextcolor(WHITE);
	char s5[] = "按任意键继续。。。";
	while (x)
	{
		kbhit();
		c = getch();
		switch (c)
		{
		case '1':rank = 300; x = 0; tt = 0;
			outtextxy(250, 390, s5);
			break;


		case '2':rank = 200; x = 0; tt = 0;
			outtextxy(250, 390, s5);
			break;


		case '3':rank = 80; x = 0; tt = 0;
			outtextxy(250, 390, s5);
			break;

		default:x = 1; outtextxy(250, 390, s7); break;
		}
	}
	_getch();
} //菜单
void upgrade() {}

void __cdecl fprintf()
{
}


int biteSelf() {
	NODE* self;
	self = s.HEAD->NEXT;
	while (self != NULL)
	{
		if (self->x == s.HEAD->x && self->y == s.HEAD->y)//蛇身坐标与蛇头重合,判断蛇死亡
		{
			return 1;
		}
		self = self->NEXT;
	}
	return(0);
}

void Data()
{
	FILE* pf = fopen("123.txt", "w"); //以只写的方式打开文件
	if (pf == NULL) //打开文件失败
	{
		printf("保存最高得分记录失败\n");
		exit(0);
	}
	fwrite(&score, sizeof(int), 1, pf); //将本局游戏得分写入文件当中
	fclose(pf); //关闭文件
	pf = NULL; //文件指针及时置空
	
}



 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/275533.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 刷题日志

文章目录 1954. 收集足够苹果的最小花园周长思考&#xff1a;暴力枚举代码实现二分查找代码实现 1954. 收集足够苹果的最小花园周长 1954. 收集足够苹果的最小花园周长 难度&#xff1a; 中等 题目大意&#xff1a; 给你一个用无限二维网格表示的花园&#xff0c;每一个 整…

Spring Boot + Mybatis + vue2 — 实现分页查询

后端 pom.xml文件导入依赖 <!--分页查询--> <dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.4.6</version> </dependency> 配置全局配置…

Python接口自动化之requests请求统一封装

还记得我们之前写的get请求、post请求么&#xff1f; 大家应该有体会&#xff0c;每个请求类型都写成单独的函数&#xff0c;代码复用性不强。 接下来将请求类型都封装起来 自动化用例都可以用这个封装的请求类进行请求&#xff0c;我们将常用的get、post请求封装起来。 imp…

亚信安慧AntDB数据库——通信运营商核心系统的全面演进

AntDB数据库源自通信运营商核心系统&#xff0c;经过15年的平稳运行和不断演进&#xff0c;成功跟随通信技术的升级步伐&#xff0c;逐步迈向5G时代&#xff0c;并且在这期间完成了8次大版本的迭代&#xff0c;为行业树立了技术领先的典范。其独特之处在于具备超融合架构&#…

Laravel的知识点

1.{{ }} 是在 HTML 中内嵌 PHP 的 Blade 语法标识符&#xff0c;表示包含在该区块内的代码都将使用 PHP 来编译运行。 2.两种写法 3.return void 在这段注释中&#xff0c;"return void" 表示该函数或方法没有返回值。这意味着它执行某些操作或任务&#xff0c;但…

数据结构学习 Leetcode494 目标和

关键词&#xff1a;动态规划 01背包 dfs回溯 一个套路&#xff1a; 01背包&#xff1a;空间优化之后dp【target1】&#xff0c;遍历的时候要逆序遍历完全背包&#xff1a;空间优化之后dp【target1】&#xff0c;遍历的时候要正序遍历 题目&#xff1a; 解法一&#xff1a; …

专为初学者设计:Nutch库Java下载器入门指南

概述: Nutch是一款开源的Java爬虫框架&#xff0c;用于抓取、解析、提取和存储网页数据。基于Hadoop的分布式系统&#xff0c;Nutch支持大规模网络爬取&#xff0c;并提供各种插件&#xff0c;包括链接分析、语言检测和内容过滤等功能。 本文旨在介绍如何使用Nutch库编写简单…

Python自动化测试:选择最佳的自动化测试框架

在开始学习python自动化测试之前&#xff0c;先了解目前市场上的自动化测试框架有哪些&#xff1f; 随着技术的不断迭代更新&#xff0c;优胜劣汰也同样发展下来。从一开始工具型自动化&#xff0c;到现在的框架型&#xff1b;从一开始的能用&#xff0c;到现在的不仅能用&…

SD-WAN企业组网的核心要点

随着企业网络需求的不断演进和全球化业务的扩张&#xff0c;SD-WAN&#xff08;软件定义广域网&#xff09;作为一种先进的网络架构技术&#xff0c;逐渐成为企业组网的首选方案。SD-WAN通过提供更灵活、高效和安全的网络连接&#xff0c;帮助企业轻松应对不同地区和业务需求。…

C++ 之LeetCode刷题记录(三)

&#x1f604;&#x1f60a;&#x1f606;&#x1f603;&#x1f604;&#x1f60a;&#x1f606;&#x1f603; 开始cpp刷题之旅&#xff0c;多学多练&#xff0c;尽力而为。 先易后难&#xff0c;先刷简单的。 13、罗马数字转整数 罗马数字包含以下七种字符: I&#xff0c…

跨境电商引流真的很难吗?了解一下这些技巧!

随着全球电商市场的不断扩大&#xff0c;越来越多的企业开始涉足跨境电商领域&#xff0c;然而&#xff0c;与国内电商相比&#xff0c;跨境电商面临着诸多挑战&#xff0c;其中最大的难题之一就是如何有效地吸引潜在客户。 很多卖家觉得跨境电商引流非常困难&#xff0c;但实…

[Angular] 笔记 12:模板驱动表单 - ngForm

Angular For Beginners - 16. Template Driven Forms (ngForm) Angular 以其表单模块而闻名。 Angular 有两种类型的表单&#xff1a; Template 以及 Reactive&#xff1a; Template 表单的特点&#xff1a;简单&#xff0c;神奇&#xff0c;一键点击。 Reactive 表单的特点&…

RabbitMQ 报错:Failed to declare queue(s):[QD, QA, QB]

实在没想到会犯这种低级错误。 回顾整理一下吧&#xff1a; 原因&#xff1a;SpringBoot主配置类默认只会扫描自己所在的包及其子包下面的组件。其他位置的配置不会被扫描。 如果非要使用其他位置&#xff0c;就需要在启动类上面指定新的扫描位置。注意新的扫描位置会覆盖默…

C# 学习网站

C# 文档 - 入门、教程、参考。 | Microsoft Learnhttps://learn.microsoft.com/zh-cn/dotnet/csharp/ Browse code samples | Microsoft LearnGet started with Microsoft developer tools and technologies. Explore our samples and discover the things you can build.http…

uniapp开发移动端遇到的问题记录

1. 键盘弹起时页面整体上移问题 很常见但我解决过程中遇到了很多问题 我的键盘没有遮盖到输入框&#xff0c;但手机键盘弹起后&#xff0c;form部分会整体上移一点&#xff0c;并且底部的操作也会弹到键盘上方 网上写得很复杂&#xff0c;什么动态赋值高度balabala。看到有一…

性能测试-jmeter:安装 / 基础使用

一、理解jmeter 官网-Apache JMeter-Apache JMeter™ JMeter是一款开源的性能测试工具&#xff0c;主要用于模拟大量用户并发访问目标服务器&#xff0c;以评估服务器的性能和稳定性。 JMeter可以执行以下任务序号用途描述1性能测试通过模拟多个用户在同一时间对服务器进行请…

16-网络安全框架及模型-BiBa完整性模型

目录 BiBa完整性模型 1 背景概述 2 模型原理 3 主要特性 4 优势和局限性 5 应用场景 BiBa完整性模型 1 背景概述 Biba完整性模型是用于保护数据完整性的模型&#xff0c;它的主要目标是确保数据的准确性和一致性&#xff0c;防止未授权的修改和破坏。在这个模型中&#…

echarts 柱状图

记录echarts 柱状图基础案例以及相关配置。 1.基础柱状图 const myChart this.$echarts.init(this.$refs.echartsZx);const option {title: {text: 本周考试记录},//提示框tooltip: {trigger: axis,axisPointer: {type: shadow}},xAxis: {type: category,data: [Mon, Tue, W…

Apache Commons Pool的对象池技术

第1章&#xff1a;引言 咱们今天来聊聊一个在Java开发中超级实用&#xff0c;但又经常被忽视的技术——对象池技术。可能你们已经听说过“对象池”这个名词&#xff0c;但对它的具体作用和重要性还有些模糊。别急&#xff0c;小黑带你们一步步深入了解。 想象一下&#xff0c…

k8s集群etcd备份与恢复

一、前言 k8s集群使用etcd集群存储数据&#xff0c;如果etcd集群崩溃了&#xff0c;k8s集群的数据就会全部丢失&#xff0c;所以需要日常进行etcd集群数据的备份&#xff0c;预防etcd集群崩溃后可以使用数据备份进行恢复&#xff0c;也可用于重建k8s集群进行数据恢复 二、备份…
最新文章