百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

小伙仅用200行C++代码,实现贪吃蛇小游戏(附源码)

ztj100 2024-10-29 18:21 17 浏览 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; }

初学编程的同学可以参考 联系我学习



相关推荐

如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL

阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...

Python数据分析:探索性分析

写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...

CSP-J/S冲奖第21天:插入排序

...

C++基础语法梳理:算法丨十大排序算法(二)

本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...

C 语言的标准库有哪些

C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...

[深度学习] ncnn安装和调用基础教程

1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...

用rust实现经典的冒泡排序和快速排序

1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...

ncnn+PPYOLOv2首次结合!全网最详细代码解读来了

编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...

C++特性使用建议

1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...

Qt4/5升级到Qt6吐血经验总结V202308

00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...

到底什么是C++11新特性,请看下文

C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...

掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!

C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...

经典算法——凸包算法

凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...

一起学习c++11——c++11中的新增的容器

c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...

C++ 编程中的一些最佳实践

1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...

取消回复欢迎 发表评论: