C语言贪吃蛇之BUG满天飞

news2025/1/11 15:10:50

C语言贪吃蛇之BUG满天飞

今天无意间翻到了大一用C语言写的贪吃蛇,竟然还标注着BUG满天飞,留存一下做个纪念,可能以后就找不到了

在这里插入图片描述

/*
此程序 -->
贪吃蛇3.0  Sur_流沐 
 
     当前版本: Bug满天飞 
*/
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>
#include<conio.h>
#include<time.h>

#define Wide 88//边框宽 
#define High 44//边框高 

#define snack_HP 3//初始生命 

#define snack_Length 3  //蛇的初始长度 
#define snack_Sleep 500  //蛇的移动速度 

#define Bomb_snack_Length 6 //出现炸弹时的蛇长 
#define Bomb_num 0//初始炸弹个数 

#define GoTo gotoxy(Wide+2,High+1)//将光标移至边框外 

struct food{//食物 
	int x;
	
	int y;
}food;

struct snack{//蛇 
	
	int x[100];
	
	int y[100];
	
	int sleep;//蛇移动速度 
	
	int length;//蛇长 
	
	int HP;//蛇的命数 
	
	int sum_score;//分数 
}snack;

struct bomb{
	int x[500];
	
	int y[500];
	
	int num;//炸弹个数 
}bomb; 


int snack_x,snack_y; //保存蛇头位置的变量 // 用于蛇头位置的改变 

int i , e , k , m ; // ‘i’多用于循环 //      ‘e’ 通常传递判断条件是否成立 //  'k 'm  用法类似 

char ch = 'a';//初始化移动方向为向 左 

 

void gotoxy(int x,int y);//坐标函数 

void come();//初始化游戏 

void menu();//封面 

void rim();//边框

void DarwSnack();//画蛇

void DarwFood();//画食物

void move();//移动蛇身坐标 
 
void DarwSnack_move();//蛇移动 

void eat();//吃食物 

void score();//评分系统 

void DarwBomb();//产生炸弹

void Bomb_eat();//检查是否吃到炸弹 



int main(){
	
	come();//初始化 
	
	
	return 0;
 } 
 
 
 
void gotoxy(int x,int y){ //坐标函数
	
	HANDLE handle = GetStdHandle (STD_OUTPUT_HANDLE);
	
	COORD  coord;
	
	coord.X = x;
	
	coord.Y = y;
	
	SetConsoleCursorPosition (handle,coord);
}

void come(){//初始化 蛇 及 炸弹 信息 


    k = 500 , snack.sum_score = 0 , snack.HP = snack_HP;

  	snack.length = snack_Length;//初始蛇长 
    	
   	snack.sleep = snack_Sleep;//初始蛇速度 

   	snack.x[0] = Wide/2,snack.y[0] = High/2;//初始蛇头位置 
    	
   	for (i = 1;i<snack.length;i++)//使用循环初始化蛇身 
    {      
        		snack.x[i] = snack.x[i-1]+2;//初始蛇身坐标 
    	
            	snack.y[i] = snack.y[i-1]; 
	}
	
	bomb.num = Bomb_num ;//初始化炸弹个数 
	
	menu(); 
}

void menu(){//封面 

    system("color 3E");
    
    system("mode con cols=140 lines=50");//改变窗口宽高 //  cols 宽  lines 高 
    
    
	
	 
	
	gotoxy(6,3);
	
	printf("贪吃蛇3.0终极版!  ——Sur流沐");
	
	gotoxy(12,6);
	
	
	
	system("pause"); 
	
	system("cls");
	
	rim();
	
	
	
	DarwSnack();//第一次调用‘画蛇函数’目的是初始化蛇 
	
	DarwFood();//第一次调用‘画食物函数’母的初始化食物 
	
	DarwSnack_move();//游戏开始 
	
} 
	 
void rim(){//边框 

	for (i = 0;i<=Wide;i+=2)
	{
		gotoxy(i,0);
		
		printf("■");
		
		gotoxy(i,High);
		
		printf("■");
		
	}
	
	for (i = 0;i<=High;i++)
	{
		gotoxy(0,i);
		
		printf("■");
		
		gotoxy(Wide,i);
		
		printf("■");
		
	}
	
	 gotoxy(Wide+4,40);
	 
	 printf("按任意键暂停!!");
	 
	 gotoxy(Wide+4,30);
	 
	 printf("tip:当蛇长超过5时随机产生炸弹!");
	 
	 gotoxy(Wide+4,32);
	 
	 printf("吃到炸弹会扣除蛇长及分数哦!!"); 
	 
	 gotoxy(Wide+4,34);
	 
	 printf("如果蛇长大于12,将无视炸弹带来的生命伤害");
	 
	 gotoxy(Wide+4,44);
	 
	 printf("BUG太多,不想修复了!!");
	 
	 gotoxy(Wide+30,2);
	 
	 printf("W-上");
	 
	 gotoxy(Wide+25,4);
	 
	 printf("A-左      D-右");
	 
	 gotoxy(Wide+30,6);
	 
	 printf("S-下");
	
	GoTo;//将光标移到框外 。见宏定义 
}
				
void DarwFood(){//画食物 

	srand((int)time(NULL));
	
    for(i = 1;i!=0;)
    {
    	food.x = rand()%10*4 + rand()%10*4 ;
    	
        food.y = rand()%10*2 + rand()%10*2 ;
               
        if((food.x != 0 && food.y != 0) && (food.x!=snack.x[0] && food.y !=snack.y[0]) && (food.x < Wide && food.y < High))
        {
        	i=0;
		}
	}
	
	gotoxy(food.x,food.y);
	
	printf("◆");
 } 
	
void DarwSnack(){//画蛇

	    
    gotoxy(snack.x[0],snack.y[0]);//光标移至蛇头位置 
    
    printf("◎");//打印蛇头 
    
    for (i = 1;i<snack.length;i++)//使用循环打印蛇身 
    {   	
    	gotoxy(snack.x[i],snack.y[i]);//光标移至某段蛇身 
    	
    	printf("○");//打印蛇身 
	}
	

}

void move(){//移动蛇身坐标 
	
	gotoxy(snack.x[snack.length-1],snack.y[snack.length-1]);//光标移至蛇尾, 
	
	printf(" ");//在蛇尾打印空格,使蛇有向前移动的状态之一 
	
	for (i = snack.length-1;i>0;i--)//依次改变蛇身的坐标 
	{
		snack.x[i] = snack.x[i-1];
		
		snack.y[i] = snack.y[i-1];
	}
	
	snack.x[0] = snack_x , snack.y[0] = snack_y;//将上次位置改变后的蛇头位置给蛇头///   即 变换后的蛇头的位置 
	
	DarwSnack();//画出蛇 
	
	score();
	
	Sleep(snack.sleep);
	
	if(snack.sleep!=snack_Sleep-450)
	
	snack.sleep-=5;
	
	
 } 

void DarwSnack_move(){//移动蛇 
	
	while(1)
 	{
 		
 		snack_x = snack.x[0] , snack_y = snack.y[0]; 
 		
 		if(kbhit()){ //kbhit   检测键盘是否有输入,//有返回  
            //用ch接收输入 
            ch=getch();
        }
        
        
        switch(ch)
        {
        	case 'A':
        		case 'a':
        			snack_x-=2;  
        			
        		    eat();
        		    
        		    if(e)
        		    {
        		    	snack.x[snack.length-1] = snack.x[snack.length-2] + 2;
        		    	
        		    	snack.y[snack.length-1] = snack.y[snack.length-2];
					}
					
					move();
					
					break;
					
        	case 'W':
        		case 'w':
        			snack_y--;  
        			
        		    eat();
        		    
        		    if(e)
        		    {
        		    	snack.x[snack.length-1] = snack.x[snack.length-2];
        		    	
        		    	snack.y[snack.length-1] = snack.y[snack.length-2] + 1;
					}
					
					move();
					
					break;
					
        	case 'S':
        		case 's':
        			snack_y++;  
        			
        		    eat();
        		    
        		    if(e)
        		    {
        		    	snack.x[snack.length-1] = snack.x[snack.length-2];
        		    	
        		    	snack.y[snack.length-1] = snack.y[snack.length-2] - 1;
					}
					
					move();
					
					break;
					
        	case 'D':
        		case 'd':
        			snack_x+=2;  
        			
        		    eat();
        		    
        		    if(e)
        		    {
        		    	snack.x[snack.length-1] = snack.x[snack.length-2] - 2;
        		    	
        		    	snack.y[snack.length-1] = snack.y[snack.length-2];
					}
					
					move();
					
					break;
			}					
	
	}
	
}
								
void eat(){//吃食物 
	
    Bomb_eat();//检查是否吃到了炸弹 
	
	e = 0; 
	
	if(snack.x[0] == food.x && snack.y[0] == food.y)//如果吃到食物 
	{
		snack.length++;//蛇长增1 
		
		e = 1;
		
		snack.sum_score += 40 ;//分数增加 
		
		DarwFood();
		
		if(snack.length >= Bomb_snack_Length)//如果蛇长满足产生炸弹的条件 
		{
			DarwBomb();//产生炸弹 
		 } 
		
	}
	
	if(snack.x[0] == 0 || snack.y[0] == 0 || snack.x[0] == Wide || snack.y[0] == High || snack.HP == 0)//游戏结束条件 
	{
		system("cls");
		
		score();
		
		gotoxy(Wide/2,High/2);
		
		printf("你over了。。。。。。。\n\n\n\t\t\t");
		
		system("pause");
		
		system("cls");
		
		menu();
	}
}

void score(){ //计分版及公告 
	
	 gotoxy(Wide+4,2);
	 
	 printf("Sur_流沐__制作!");
	 
	 gotoxy(Wide+4,4);
	 
	 printf("贪吃蛇3.0终极版!");
	 
	 gotoxy(Wide+4,6);
	 
	 printf("速度范围0~%d",snack_Sleep-50);
	 
	 gotoxy(Wide+4,10);
	 
	 printf("当前分数:%d",snack.sum_score);
	 
	 gotoxy(Wide+4,12);
	 
	 printf("当前速度:%d",snack_Sleep-snack.sleep) ;
	 
	 gotoxy(Wide+4,14);
	 
	 printf("当前蛇长:%d",snack.length);
	 
	 gotoxy(Wide+4,16);
	 
	 printf("剩余炸弹:%d",500 - bomb.num);	
	 
	 gotoxy(Wide+4,18);
	 
	 printf("你还有%d条生命!",snack.HP); 
} 

void DarwBomb(){//产生炸弹 
	
	bomb.num ++ ;//炸弹个数增加 
	
	m = 1;
	
	srand((int)time(NULL));
	
	for(i = bomb.num -1; m!=0 ; )//随机产生炸弹 
	{
	    for(m = 1;m!=0;)
        {
        	bomb.x[i] = rand()%10*4 + rand()%10*4 + rand()%10*2 ;
    	
            bomb.y[i] = rand()%10*2 + rand()%10*2 ;
               
            if((bomb.x[i] != 0 && bomb.y[i] != 0) && (bomb.x[i] != snack.x[0] && bomb.y[i] !=snack.y[0]) && (bomb.x[i] < Wide && bomb.y[i] < High) && (bomb.x[i] != food.x)&&(bomb.y[i] != food.y))
            {
            	m = 0;
	    	}
    	}
	
    	gotoxy(bomb.x[i],bomb.y[i]);
	
    	printf("※");

	}
    	
}

void Bomb_eat(){//吃到炸弹?????? 
	
	for(i = 0 ; i < bomb.num ; i++)
	{
		if(snack.x[0] == bomb.x[i] && snack.y[0] == bomb.y[i])//如果吃到炸弹 
		{
			snack.sum_score-=100 ;//分数减去100 
			
			if(snack.length <= 11)//如果蛇长过短 
			{
				snack.HP--;//扣除生命值 
				
				for( m = 0 ; m < bomb.num ; m++ )//扣除生命值的同时清除现存所有炸弹 
				{
					gotoxy(bomb.x[m],bomb.y[m]);
					
					printf(" ");
					
						
			        bomb.x[m] = Wide + 1 ;
			
		        	bomb.x[m] = High + 1 ;//将炸弹坐标清除 
				}
			}
			
			
			//适于当蛇长大于11 //如果吃到炸弹 
			bomb.x[i] = Wide + 1 ;
			
			bomb.x[i] = High + 1 ;//将被吃到的炸弹坐标清除 
			
			k = snack.length - 1;
			
			snack.length-=5;	//蛇长减5 
			
			if(snack.length >= 1)//清除蛇尾 
			{
				for(m = k ; m > k - 5 ; m-- )
				{
					gotoxy(snack.x[m] , snack.y[m]);
					
					printf(" ");
				}
			}
			
			if(snack.length <= 1)//保持蛇长大于1 
			{
				snack.length = 1 ;
				
				snack.sleep += 100;
				
				if(snack.sleep <= 50)//控制蛇速范围 
				{
					snack.sleep = 20 ;
				}
			}
		}
	}
 } 
 
 
 
 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux C、C++编程之线程同步

【图书推荐】《Linux C与C一线开发实践&#xff08;第2版&#xff09;》_linux c与c一线开发实践pdf-CSDN博客《Linux C与C一线开发实践&#xff08;第2版&#xff09;&#xff08;Linux技术丛书&#xff09;》(朱文伟&#xff0c;李建英)【摘要 书评 试读】- 京东图书 (jd.com…

qt处理表格,Qtxlsx库文件的安装以及导入

qt想要处理excel表格的&#xff0c;这个过程中避免不了使用Qtxlsx这个库文件。这几天花了几天时间&#xff0c;终于本地调通了。记录一下。 关于Qtxlsx的使用&#xff0c;大致分为2中方法。 方法一&#xff1a;直接下载对应的xlsx文件&#xff0c;然后在.pro文件中 这种方法是…

使用Java往Geoserver发布tif图层和shp图层

1. Maven依赖 栅格文件对应Tif文件 (即: 栅格就是tif) 矢量文件对应shp文件(即: 矢量就是shp) 注: 有的依赖可能在中央仓库及一些镜像仓库找不到需要手动指定仓库, 在依赖最下方 <!-- 中文转拼音工具类 --><dependency><groupId>com.belerweb</groupId&g…

指针的学习和理解

初级 1、指针的概念 在64位操作系统中&#xff0c;不管什么类型的指针都占8个字节 int a1; int* p&a;//p就是一个整型的指针&#xff0c;保存了a的地址2、指针和变量 int* p&a;* p100; // 等价于a100p //p&a*有两种定义&#xff1a; 定义的时候&#xff08;前…

【工具类】Java优雅的将XML转为JSON格式、XML转JSON

Java优雅的将XML转为JSON格式、XML转JSON 1. 导入依赖1.1 Maven使用1.2 Gradle使用 2. 代码编写3.运行示例 1. 导入依赖 1.1 Maven使用 <dependency><groupId>org.dom4j</groupId><artifactId>dom4j</artifactId><version>2.1.3</vers…

TCP连接过程

文章目录 TCP连接过程 附录TCP报文中关键术语字段 后面再完整出理论、出实战、出总结 TCP连接过程 三次握手&#xff08;Three-Way Handshake&#xff09;过程。 TCP抓包结果分析&#xff1a; step1&#xff1a;Client1客户端--->Server1服务器发送SYN&#xff08;同步…

【C++二分查找 前缀和】1658. 将 x 减到 0 的最小操作数

本文涉及的基础知识点 C二分查找 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 LeetCode1658. 将 x 减到 0 的最小操作数 给你一个整数数组 nums 和一个整数 x 。每一次操作时&#xff0c;你应当移除数组 nums 最左边或最右边的元素&am…

MambaCSR: 使用SSM的双交错扫描压缩图像超分辨率

MambaCSR: Dual-Interleaved Scanning for Compressed Image Super-Resolution With SSMs 2408.11758 (arxiv.org) GitHub - renyulin-f/MambaCSR: The code source of MambaCSR 摘要 本文提出了MambaCSR&#xff0c;这是一个基于Mamba的简单但有效的框架&#xff0c;用于解决…

ffmpeg读取时长、读取视频格式

ffmpeg读取时长、读取视频格式 ffmpeg读取时长ffmpeg读取视频格式 ffmpeg读取时长 命令命令介绍具体用法ffmpeg -i查看视频时长ffmpeg -i 视频链接 or 视频路径 2>&1 | grep Duration ffmpeg读取视频格式 命令命令介绍具体用法ffmpeg -i查看视频时长ffmpeg -i 视频链接…

集合及数据结构第八节(下)———— 队列(Queue)、队列的模拟实现和练习

系列文章目录 集合及数据结构第八节&#xff08;下&#xff09;———— 队列(Queue)、队列的模拟实现和练习 队列(Queue)、队列的模拟实现和练习 队列的概念队列的使用队列模拟实现循环队列双端队列练习题 文章目录 系列文章目录集合及数据结构第八节&#xff08;下&#x…

Chainlit接入DifyAI知识库接口快速实现自定义用户聊天界面

前言 由于dify只提供了一个分享用的网页应用&#xff0c;网页访问地址没法自定义&#xff0c;虽然可以接入NextWeb/ChatGPT web/open webui等开源应用。但是如果我们想直接给客户应用&#xff0c;还需要客户去设置配置&#xff0c;里面还有很多我们不想展示给客户的东西怎么办…

【C语言】文件操作 (详细!!)

1、为什么使用文件 使用文件的原因&#xff1a;使用文件主要是为了在程序的执行过程中保存、读取和交换数据。文件提供了一种持久化存储数据的方式&#xff0c;使得程序在关闭后&#xff0c;数据不会丢失&#xff0c;可以被其他程序或后续的程序执行周期重新读取和处理。 1.0 什…

实验2-1-3 输出三角形

本题要求编写程序&#xff0c;输出指定的由“*”组成的三角图案。 **输入格式&#xff1a; 本题无输入**输出格式&#xff1a; 按照下列格式输出由“*”组成的三角图案。 **** *** ** *程序: #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> int main() {int i…

leetcode 49 字母异位分词

正文 基础解法 首先&#xff0c;我们创建一个字典对象&#xff0c;然后遍历整个字符串列表&#xff0c;并且使用 sorted() 函数对字符串列表进行排序&#xff0c;所有的异位分词经过排序后它们的组成和顺序会趋于一致。但是需要注意的是 sorted 对字符串进行排序后会变成一个由…

基于element-ui 日期选择器el-date-picker, 即对日期做区间限制

需求&#xff1a; 有时候需求会让我们对日期选择器做限制&#xff0c;即控制最多可跨越多少个月份&#xff0c;其中涉及到不同年份该如何计算。 HTML&#xff1a; <el-date-pickerv-model"timePeriod"type"monthrange"value-format"yyyyMM"…

Linux系统之部署俄罗斯方块网页小游戏(三)

Linux系统之部署俄罗斯方块网页小游戏(三) 一、小游戏介绍1.1 小游戏简介1.2 项目预览二、本次实践介绍2.1 本地环境规划2.2 本次实践介绍三、检查本地环境3.1 检查系统版本3.2 检查系统内核版本3.3 检查软件源四、安装Apache24.1 安装Apache2软件4.2 启动apache2服务4.3 查看…

【CANoe使用大全】——cdd导入CANoe流程详解

&#x1f64b;‍♂️【CANoe使用大全】系列&#x1f481;‍♂️点击跳转 文章目录 1.1.CDD导入1.1 CDD文件导入流程 2. CDD文件导后配置2.1.协议配置2.2.寻址方式配置2.3.0x27 解密DLL导入2.4.诊断ID配置 3.导入效果4.CDD操作台使用4.1.指令发送 5.Fault Memory5.1 0x19 045.2…

解释图像的边缘检测算法中的Canny算法

Canny 算法是图像处理领域中一种经典的边缘检测方法&#xff0c;由 John F. Canny 在 1986 年提出。Canny 算法以其高效、可靠的边缘检测效果在图像处理和计算机视觉领域广泛应用。它具有良好的噪声抑制能力、精确的边缘定位能力以及单像素宽度的边缘输出特性。 Canny 边缘检测…

TIM输出比较之PWM驱动LED呼吸灯应用案例

文章目录 前言一、应用案例演示二、电路接线图三、应用案例代码四、应用案例分析4.1 基本思路4.2 相关库函数介绍4.3 初始化PWM模块4.3.1 RCC开启时钟4.3.2 配置时基单元4.3.3 配置输出比较单元4.3.4 配置GPIO4.3.5 运行控制 4.4 PWM输出模块4.5 主程序 前言 提示&#xff1a;…

无人机培训与装配维修技术详解

一、无人机基础理论 无人机&#xff0c;即无人驾驶航空器&#xff0c;凭借其灵活性、高效性和广泛应用性&#xff0c;已成为现代科技领域的热点之一。在学习无人机培训与装配维修技术之前&#xff0c;掌握无人机的基础理论是必不可少的。这包括但不限于&#xff1a; 1. 无人机…