小伙仅用200行C++代码,实现贪吃蛇小游戏(附源码)
ztj100 2024-10-29 18:21 22 浏览 0 评论
小编是一个有着6年工作经验的工程师,关于C++编程,自己有做材料的整合,一个完整的C++编程学习路线,学习资料和工具,能够进我的群10048,-83029收取,免费送给大家,希望你也能凭着自己的努力,成为下一个优秀的程序员
#include<stdio.h> #include<process.h> #include<windows.h> #include<conio.h> #include<time.h> #include<stdlib.h> #define WIDTH 40 #define HEIGH 12 enum direction{//方向 LEFT, RIGHT, UP, DOWN }; struct Food{//食物 int x; int y; }; struct Node{//画蛇身 int x; int y; struct Node *next; }; struct Snake{//蛇属性 int lenth;//长度 enum direction dir;//方向 }; struct Food *food; //食物 struct Snake *snake;//蛇属性 struct Node *snode,*tail;//蛇身 int SPEECH=200; int score=0;//分数 int smark=0;//吃食物标记 int times=0; int STOP=0; void Initfood();//产生食物 void Initsnake();//构造snake void Eatfood();//头部前进 void Addnode(int x, int y);//增加蛇身 void display(struct Node *shead);//显示蛇身坐标 void move();//蛇移动 void draw();//画蛇 void Homepage();//主页 void keybordhit();//监控键盘按键 void Addtail();//吃到食物 void gotoxy(int x, int y)//定位光标 { COORD pos; pos.X = x - 1; pos.Y = y - 1; SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),pos); } void Initsnake()//构造snake { int i; snake=(struct Snake*)malloc(sizeof(struct Snake)); tail=(struct Node*)malloc(sizeof(struct Node)); food = (struct Food*)malloc(sizeof(struct Food)); snake->lenth=5;//初始长度 5 snake->dir=RIGHT;//初始蛇头方向 右 for(i=2;i<=snake->lenth+2;i++)//增加 5 个结点 { Addnode(i,2); } } void Initfood()//产生食物 { struct Node *p=snode; int mark=1;
srand((unsigned)time(NULL));//以时间为种子产生随机数 while(1) { food->x=rand()%(WIDTH-2)+2;//食物X坐标 food->y=rand()%(HEIGH-2)+2;//食物Y坐标 while(p!=NULL) { if((food->x==p->x)&&(food->y==p->y))//如果食物产生在蛇身上 {//则重新生成食物 mark=0;//食物生成无效 break; } p=p->next; } if(mark==1)//如果食物不在蛇身上,生成食物,否则重新生成食物 { gotoxy(food->x,food->y); printf("%c",3); break; } mark=1; p=snode; } } void move()//移动 { struct Node *q, *p=snode; if(snake->dir==RIGHT) { Addnode(p->x+1,p->y); if(smark==0) { while(p->next!=NULL) { q=p; p=p->next; } q->next=NULL; free(p); } } if(snake->dir==LEFT) { Addnode(p->x-1,p->y); if(smark==0) { while(p->next!=NULL) { q=p; p=p->next; } q->next=NULL; free(p); } } if(snake->dir==UP) { Addnode(p->x,p->y-1); if(smark==0) { while(p->next!=NULL) { q=p; p=p->next; } q->next=NULL; free(p); } } if(snake->dir==DOWN) { Addnode(p->x,p->y+1); if(smark==0) { while(p->next!=NULL) { q=p; p=p->next; } q->next=NULL; free(p); } } } void Addnode(int x, int y)//增加蛇身 { struct Node *newnode=(struct Node *)malloc(sizeof(struct Node)); struct Node *p=snode; newnode->next=snode; newnode->x=x; newnode->y=y; snode=newnode;//结点加到蛇头 if(x<2||x>=WIDTH||y<2||y>=HEIGH)//碰到边界 { STOP=1; gotoxy(10,19); printf("撞墙,游戏结束,任意键退出!\n");//失败 _getch(); free(snode);//释放内存 free(snake); exit(0); } while(p!=NULL)//碰到自身 { if(p->next!=NULL) if((p->x==x)&&(p->y==y)) { STOP=1; gotoxy(10,19); printf("撞到自身,游戏结束,任意键退出!\n");//失败 _getch(); free(snode);//释放内存 free(snake); exit(0); } p=p->next; } } void Eatfood()//吃到食物 { Addtail(); score++; } void Addtail()//增加蛇尾 { struct Node *newnode=(struct Node *)malloc(sizeof(struct Node)); struct Node *p=snode; tail->next=newnode; newnode->x=50; newnode->y=20; newnode->next=NULL;//结点加到蛇头 tail=newnode;//新的蛇尾 } void draw()//画蛇 { struct Node *p=snode; int i,j; while(p!=NULL) { gotoxy(p->x,p->y); printf("%c",2); tail=p; p=p->next; } if(snode->x==food->x&&snode->y==food->y)//蛇头坐标等于食物坐标 { smark=1; Eatfood();//增加结点 Initfood();//产生食物 } if(smark==0) { gotoxy(tail->x,tail->y);//没吃到食物清除之前的尾结点 printf("%c",' ');//如果吃到食物,不清楚尾结点 } else { times=1; } if((smark==1)&&(times==1)) { gotoxy(tail->x,tail->y);//没吃到食物清除之前的尾结点 printf("%c",' ');//如果吃到食物,不清楚尾结点 smark=0; } gotoxy(50,12); printf("食物: %d,%d",food->x,food->y); gotoxy(50,5); printf("分数: %d",score); gotoxy(50,7); printf("速度: %d",SPEECH); gotoxy(15,14); printf("按o键加速"); gotoxy(15,15); printf("按p键减速"); gotoxy(15,16); printf("按空格键暂停"); } void HideCursor()//隐藏光标 { CONSOLE_CURSOR_INFO cursor_info = {1, 0}; SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &cursor_info); } void Homepage()//绘主页 { int x,y; HideCursor();//隐藏光标 printf("----------------------------------------\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("|\t\t\t\t |\n"); printf("----------------------------------------\n"); gotoxy(5,13); printf("任意键开始游戏!按W.A.S.D控制方向"); _getch(); Initsnake(); Initfood(); gotoxy(5,13); printf(" "); } void keybordhit()//监控键盘 { char ch; if(_kbhit()) { ch=getch(); switch(ch) { case 'W': case 'w':if(snake->dir==DOWN)//如果本来方向是下,而按相反方向无效 { break; } else snake->dir=UP;break; case 'A': case 'a':if(snake->dir==RIGHT)//如果本来方向是右,而按相反方向无效 { break; } else snake->dir=LEFT;break; case 'S': case 's':if(snake->dir==UP)//如果本来方向是上,而按相反方向无效 { break; } else snake->dir=DOWN;break; case 'D': case 'd':if(snake->dir==LEFT)//如果本来方向是左,而按相反方向无效 { break; } else snake->dir=RIGHT;break; case 'O': case 'o': if(SPEECH>=150)//速度加快 { SPEECH=SPEECH-50; } break; case 'P': case 'p': if(SPEECH<=400)//速度减慢 { SPEECH=SPEECH+50; } break; case ' '://暂停 gotoxy(15,18); printf("游戏已暂停,按任意键恢复游戏"); system("pause>nul"); gotoxy(15,18); printf(" "); break; default:break; } } } int main(void)//程序入口 { Homepage(); while(!STOP) { keybordhit();//监控键盘按键 move();//蛇的坐标变化 draw();//蛇的重绘 Sleep(SPEECH);//暂时挂起线程 } return 0; }
初学编程的同学可以参考 联系我学习
相关推荐
- 再说圆的面积-蒙特卡洛(蒙特卡洛方法求圆周率的matlab程序)
-
在微积分-圆的面积和周长(1)介绍微积分方法求解圆的面积,本文使用蒙特卡洛方法求解圆面积。...
- python创建分类器小结(pytorch分类数据集创建)
-
简介:分类是指利用数据的特性将其分成若干类型的过程。监督学习分类器就是用带标记的训练数据建立一个模型,然后对未知数据进行分类。...
- matplotlib——绘制散点图(matplotlib散点图颜色和图例)
-
绘制散点图不同条件(维度)之间的内在关联关系观察数据的离散聚合程度...
- python实现实时绘制数据(python如何绘制)
-
方法一importmatplotlib.pyplotaspltimportnumpyasnpimporttimefrommathimport*plt.ion()#...
- 简单学Python——matplotlib库3——绘制散点图
-
前面我们学习了用matplotlib绘制折线图,今天我们学习绘制散点图。其实简单的散点图与折线图的语法基本相同,只是作图函数由plot()变成了scatter()。下面就绘制一个散点图:import...
- 数据分析-相关性分析可视化(相关性分析数据处理)
-
前面介绍了相关性分析的原理、流程和常用的皮尔逊相关系数和斯皮尔曼相关系数,具体可以参考...
- 免费Python机器学习课程一:线性回归算法
-
学习线性回归的概念并从头开始在python中开发完整的线性回归算法最基本的机器学习算法必须是具有单个变量的线性回归算法。如今,可用的高级机器学习算法,库和技术如此之多,以至于线性回归似乎并不重要。但是...
- 用Python进行机器学习(2)之逻辑回归
-
前面介绍了线性回归,本次介绍的是逻辑回归。逻辑回归虽然名字里面带有“回归”两个字,但是它是一种分类算法,通常用于解决二分类问题,比如某个邮件是否是广告邮件,比如某个评价是否为正向的评价。逻辑回归也可以...
- 【Python机器学习系列】拟合和回归傻傻分不清?一文带你彻底搞懂
-
一、拟合和回归的区别拟合...
- 推荐2个十分好用的pandas数据探索分析神器
-
作者:俊欣来源:关于数据分析与可视化...
- 向量数据库:解锁大模型记忆的关键!选型指南+实战案例全解析
-
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...
- 用Python进行机器学习(11)-主成分分析PCA
-
我们在机器学习中有时候需要处理很多个参数,但是这些参数有时候彼此之间是有着各种关系的,这个时候我们就会想:是否可以找到一种方式来降低参数的个数呢?这就是今天我们要介绍的主成分分析,英文是Princip...
- 神经网络基础深度解析:从感知机到反向传播
-
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...
- Python实现基于机器学习的RFM模型
-
CDA数据分析师出品作者:CDALevelⅠ持证人岗位:数据分析师行业:大数据...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)