11 c++版本的贪吃蛇

前言

呵呵 这大概是 大学里面的 c++ 贪吃蛇了吧 

有一些 面向对象的理解, 但是不多 

最近 因为想要 在单片机上面移植一下 贪吃蛇, 所以 重新拿出了一下 这份代码 

然后 将它更新为 c 版本, 还是 用了一些时间 

这里 具体的实现 就不赘述, 仅仅是 发一下代码 以及 具体的使用 

然后 貌似 放在 win10 上面执行 还有一些问题, 渲染的, 应该很好调整 

 

 

贪吃蛇

#include<iostream>
#include<Windows.h>
#include<ctime>
#include<string>
using namespace std;void position(int ,int );
class Node	//蛇身的结点
{	
public:int x;int y;Node *next;Node(int x=0,int y=0){	this->x=x;this->y=y;next=NULL;	}
};class hero		//英雄榜的结点
{
public:string name;int score;hero(string s="anonymous",int sc=0){	name=s;score=sc;	}
};class Snake
{
private:Node *head;		//头结点Node *food;		//食物结点bool flag;		//是否吃到食物int grade;		//所得分数int level;		//游戏级别int tot;		//蛇身节点的个数int direction;	//蛇的方向int herotot;	//英雄榜人物个数hero HERO[11];	//英雄榜数据public:Snake(){		head=new Node(20,10);flag=false;direction=2;tot=1;grade=0;level=0;herotot=0;}void setmap();		  //screen's length = 78 ; width = 24;打印出地图void menu();			//菜单bool isover();			//是否游戏结束void go();				//蛇的行动void running();			//运行程序void init();			//初始化蛇身void createfood();		//创建食物bool getfood();			//吃到食物bool isfoodcover();		//食物是否出现在蛇体上bool issuccess();		//是否是成功退出void showinfo();		//看文件信息void lookhero();		//看英雄榜void print();			//打印蛇体
};int main()
{	Snake snake;char ch;system("cls");do{	snake.menu();cin>>ch;if(ch=='1')	snake.running();if(ch=='2')	snake.showinfo();if(ch=='3')	snake.lookhero();if(ch=='4')	break;}while(true);return 0;
}void position(int x,int y)
{	HANDLE handle;handle=GetStdHandle(STD_OUTPUT_HANDLE);COORD position={x,y};								 // position.x=x;position.y=ySetConsoleCursorPosition(handle,position);
}void Snake::setmap()	  	// →	←	↑	↓	⊙	□	■	※
{int i;system("cls");for(i=0;i<=39;i++){	position(2*i,0);cout<<"※";position(2*i,24);cout<<"※";Sleep(10);}for(i=23;i>0;i--){	position(0,i);cout<<"※";position(60,i);cout<<"※";position(78,i);cout<<"※";Sleep(10);}position(64,4);	cout<<"grade :"<<grade;position(64,6);	cout<<"level :"<<level;position(64,8);	cout<<"length :"<<tot;position(64,10);	cout<<"pause: right ";position(64,12);	cout<<"key of mouse .";position(64,16);	cout<<"snake";position(64,18);	cout<<"direction:";position(68,20);	cout<<"↑";position(64,22);	cout<<"←  ↓  →";position(0,0);
}  void Snake::menu()	// ∞	○	Θ
{	system("cls");for(int i=0;i<=39;i++){	position((2*i),0);	cout<<"※";position((2*i),1);	cout<<"№";position((2*i),2);	cout<<"∞";position((2*i),3);	cout<<"⊙";Sleep(20);position((2*i),24);	cout<<"○";position((2*i),23);	cout<<"∞";position((2*i),22);	cout<<"‰";position((2*i),21);	cout<<"※";}position(20,8);	cout<<"GLUTTONOUS SNAKE"<<endl;position(18,10);	cout<<"1.START";position(40,10);	cout<<"2.ABOUT GAME";position(18,14);	cout<<"3.HERO ";position(40,14);	cout<<"4.EXIT";position(18,18);	cout<<"PLEASE INPUT :  ";
}void Snake::init()
{	Node *p=head;srand((int )time(NULL));for(int i=1;i<=3;i++){	p->next=new Node(20-2*i,10);tot++;p=p->next;}
}  bool Snake::isover()
{	Node *p=head->next->next->next;if(head->x>58 || head->x<=0 || head->y>23 || head->y<=0 )	return true;while(p){	if( head->x==p->x && head->y==p->y )	return true;p=p->next;}if(level>=10)	return true;return false;
}  void Snake::createfood()
{	food=new Node;do	{	food->x=rand()%58+2;food->y=rand()%23+1;}while(isfoodcover());if(food->x%2==1)	food->x=food->x-1;position(food->x,food->y);	cout<<"□";
}  bool Snake::getfood()
{	Node *p;if(flag==true){	if((direction+2)%2==1){	p=new Node(head->x,head->y+direction);p->next=head;head=p;}else{	p=new Node(head->x+direction,head->y);p->next=head;head=p;}flag=false;}if( head->x == food->x && head->y == food->y ){	flag=true;if(grade>=100*(level+1)*(level+1)){	level++;position(71,6);cout<<level;}grade=grade+5*(level+1);position(71,4);cout<<grade;position(72,8);cout<<++tot;return true;}return false;
}bool Snake::isfoodcover()
{	Node *p=head;while(p){	if(food->x==p->x && food->y==p->y )	return true;p=p->next;}return false;
}void Snake::go()
{	if(GetAsyncKeyState(VK_UP) && direction!=1 )	direction=-1;else if(GetAsyncKeyState(VK_LEFT) && direction!=2 )	direction=-2;else if(GetAsyncKeyState(VK_DOWN) && direction!=-1 )	direction=1;else if(GetAsyncKeyState(VK_RIGHT) && direction!=-2 )	direction=2;if(GetAsyncKeyState(VK_LBUTTON)){	while(true){if(GetAsyncKeyState(VK_LBUTTON))	break;}}Node *p;if((direction+2)%2==1){	p=new Node(head->x,head->y+direction);p->next=head;head=p;while(p->next->next){	p=p->next;}position(p->next->x,p->next->y);	cout<<" ";delete p->next;p->next=NULL;print();}else {	p=new Node(head->x+direction,head->y);p->next=head;head=p;while(p->next->next){	p=p->next;}position(p->next->x,p->next->y);	cout<<" ";delete p->next;p->next=NULL;print();}Sleep(300-30*level);
}    void Snake::running()
{	Node *p;system("cls");init();setmap();createfood();int num=0;while(true){print();go();if(isover())	break;if(getfood()){	delete food;createfood();}}position(0,25);if(issuccess())	cout<<"CONGRATULATIONS YOU WIN !"<<endl;else cout<<"SORRY YOU LOSE"<<endl;cout<<"YOU GOT "<<grade<<" POINT"<<endl;cout<<"PLEASE INPUT YOUR BIG NAME: ";if(herotot<10){	cin>>HERO[herotot].name;HERO[herotot].score=grade;	herotot++;}else	{	cin>>HERO[10].name;HERO[10].score=grade;	}hero temp=HERO[herotot-1];for(int j=herotot-2;j>=0;j--){	if(HERO[herotot-1].score>HERO[j].score)	num++;else break;}for(j=0;j<num;j++)HERO[herotot-j-1]=HERO[herotot-j-2];HERO[herotot-num-1]=temp;// 还回原状p=head->next;while(p){	p=p->next;delete head->next;head->next=p;}head->x=20;head->y=10;head->next=NULL;direction=2;tot=1;grade=0;level=0;
}bool Snake::issuccess()
{	if(level>=10)	return true;return false;
}void Snake::showinfo()
{	system("cls");position(16,8);	cout<<"WELCOME TO GLUTTONOUS SNAKE";position(12,12);	cout<<"THIS IS MADE BY JERRY "<<endl<<"	  AT 2013-11-08	FRIDAY AFTERNOON";position(12,16);	system("pause");
}void Snake::lookhero()
{	system("cls");position(25,3);	cout<<"HERO BANG ";for(int i=0;i<herotot;i++){	position(12,i+7);cout<<"THE  "<<i+1<<"  TH"<<"   NAME :"<<HERO[i].name; position(47,i+7); cout<<"	SCORE :"<<HERO[i].score<<endl;}position(25,20);	system("pause");
}void Snake::print()
{Node *p=head;while(p){	position(p->x,p->y);	cout<<"■";p=p->next;}
}

 

 

程序截图

 首页

470631a91777471daeeb2ecbc707d396.png

 

 

程序执行之后如下  

c798887ae8ec4f85ac461c5c4bef1eca.png

 

 

以前在 win7 上面的截图 

a29938fe50014ccf996661df3817445d.png

 

 

 

 

 

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

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

相关文章

数据结构中的栈和队列(附实际案例代码)

1.栈和队列的定义和特点 栈&#xff08;Stack&#xff09;和队列&#xff08;Queue&#xff09;是两种基本的数据结构&#xff0c;它们都属于线性表&#xff0c;即数据元素的存储和访问都是线性的。但它们之间也存在着一些区别。 1.1栈的特点 栈是一种后进先出&#xff08;LI…

pandas数据分析综合练习50题 - 地区房价分析

数据源 我们将使用一个公开的数据集&#xff0c;“纽约市Airbnb开放数据集”。这个数据集包含了纽约市Airbnb的上万条房源信息&#xff0c;包括价格、位置、房东信息和评论数量等字段。 获取方式1 - 本文资源文件下载 可在文章绑定资源中下载。 获取方式2 - 网页下载 直接…

上位机图像处理和嵌入式模块部署(树莓派4b用skynet实现进程通信)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 前面我们说过&#xff0c;在工业系统上面一般都是使用多进程来代替多线程。这后面&#xff0c;主要的原因还是基于安全的考虑。毕竟一个系统里面&a…

Git Tag 打标签

参考地址&#xff1a;Git基础 - git tag 一文真正的搞懂git标签的使用-CSDN博客 创建标签 $ git tag -a 标签名称 -m 附注信息 or $ git tag -a 标签名称 提交版本号 -m 附注信息说明&#xff1a; -a : 理解为 annotated 的首字符&#xff0c;表示 附注标签 -m : 指定附注信息…

北斗引路,太阳为源,定位报警,保护渔业,安全护航!

2022年1月&#xff0c;农业农村部发布《“十四五”全国渔业发展规划》明确提出&#xff0c;到2025年&#xff0c;渔业质量效益和竞争力明显增强&#xff0c;渔业基础设施和装备条件明显改善&#xff0c;渔业治理体系和治理能力现代化水平明显提高&#xff0c;实现产业更强、生态…

用Excel做一个功能完备的仓库管理系统

1 基本设计思路 用到的Excel技术&#xff1a;sumif, vlookup, 表格(table)。基本思路&#xff1a;在有基础的商品、仓库等信息的情况下&#xff0c;对商品的每一个操作都有对应的单据&#xff0c;然后再汇总统计。标识&#xff1a;为了在不同的维度统计数量&#xff0c;各单据…

MySQL的主主(Master-Master)生产环境中遇到的常见问题

在MySQL的主主&#xff08;Master-Master&#xff09;生产环境中&#xff0c;由于涉及到数据的双向同步&#xff0c;可能会遇到一系列问题。以下是一些常见的问题及其简要说明&#xff1a; 数据冲突和不一致&#xff1a;由于两个主服务器都在写入数据&#xff0c;当它们几乎同时…

HarmonyOS开发案例:【使用List组件实现设置项】

介绍 在本篇CodeLab中&#xff0c;我们将使用List组件、Toggle组件以及Router接口&#xff0c;实现一个简单的设置页&#xff0c;点击将跳转到对应的详细设置页面。效果图如下&#xff1a; 相关概念 [CustomDialog]&#xff1a;CustomDialog装饰器用于装饰自定义弹窗。[List]…

Linux 权限与软件包管理器 yum

一. 研究Linux默认权限 目录 &#xff0c;起始权限&#xff1a;777 普通文件&#xff0c;起始权限666 Linux系统中存在权限掩码 使用umask指令也可以改变掩码 如果将掩码改为0000 我们可以看到权限发生改变&#xff08;重新设置掩码&#xff09; 最终权限起始权限 去掉 权限…

通过easyExcel实现表格的导入导出

本篇为&#xff0c;通过easyExcel实现 多种数据类型表格 的导入导出 引入2.2.11版本easyExcel依赖 <font color-“byle”>easyExcel版本不同&#xff0c;converter接口中的方法也不相同&#xff0c;一定要注意版本的使用 <dependency><groupId>com.alibaba&…

[华为OD] 给航天器一侧加装长方形或正方形的太阳能板 100

给航天器一侧加装长方形或正方形的太阳能板&#xff08;图中的红色斜线区域&#xff09;&#xff0c;需要先安装两个支 柱&#xff08;图中的黑色竖条&#xff09;&#xff0c;再在支柱的中间部分固定太阳能板。但航天器不同位置的支柱长度 不同&#xff0c;太阳能板的安装面…

【算法基础实验】图论-构建无向图

构建无向图 前提 JAVA实验环境 理论 无向图的数据结构为邻接表数组&#xff0c;每个数组中保存一个Bag抽象数据类型&#xff08;Bag类型需要专门讲解&#xff09; 实验数据 我们的实验数据是13个节点和13条边组成的无向图&#xff0c;由一个txt文件来保存&#xff0c;本…

python——re库

Python的re库是用于处理正则表达式的标准库&#xff0c;正则表达式是一种强大而灵活的文本处理工具&#xff0c;能够帮助你执行复杂的字符串匹配和替换操作。下面是一些基本的API及其使用场景和示例&#xff1a; 1. re.compile(pattern[, flags]) 功能&#xff1a;编译正则表…

架构师系列- JVM(三)- 类加载

通过字节码&#xff0c;我们了解了class文件的结构 通过运行数据区&#xff0c;我们了解了jvm内部的内存划分及结构 接下来&#xff0c;让我们看看&#xff0c;字节码怎么进入jvm的内存空间&#xff0c;各自进入那个空间&#xff0c;以及怎么跑起来。 4.1 加载 4.1.1 概述 …

【目标检测】YOLOv7 网络结构(与 YOLOv4,YOLOv5 对比)

YOLOv7 和 YOLOv4 Neck 与 Head 结构对比 其实 YOLOv7 的网络结构网上很多文章已经讲得很清除了&#xff0c;网络结构图也有非常多的版本可供选择&#xff0c;因为 YOLOv7 和 YOLOv4 是一个团队的作品&#xff0c;所以在网络结构方面&#xff0c; YOLOv7 和 YOLOv4 有很多相似…

用不了ChatGPT?快试试免费又强大的Anthropic Claude

一、Claude 简介 Anthropic 官方&#xff1a; https://www.anthropic.com/product Claude 是最近新开放的一款 AI 聊天机器人&#xff0c;是世界上最大的语言模型之一&#xff0c;比之前的一些模型如 GPT-3 要强大得多&#xff0c;因此 Claude 被认为是 ChatGPT 最有力的竞争…

每天一个数据分析题(二百八十五)——四分位差

四分位差是一组数据的上四分位数与下四分位数之差&#xff0c;下面选项错误的是 A. 四分位差受极端值的影响 B. 四分位差是一个局部指标&#xff0c;衡量了处于50%数据的离散程度 C. 四分位差越大&#xff0c;说明处于中间50%数据越分散 D. 顺序数据适合用四分位差来度量离…

软件开发职业发展:技能掌握、学习策略与市场适应性

软件开发职业发展&#xff1a;技能掌握、学习策略与市场适应性 首先提出一个问题&#xff1a; 现在学的语言什么的&#xff0c;哪个语言更好&#xff0c;或者是后端更主流什么&#xff1f; 编程语言技能与职业发展的关联性 编程语言的通用性 在大型科技公司&#xff0c;如华…

SpringBoot学习之Kafka发送消费消息入门实例(三十五)

使用Kafka之前需要先启动fKafka,如何下载安装启动kafka请先参考本篇文章的前两篇: 《SpringBoot学习之Kafka下载安装和启动【Windows版本】(三十四)》 《SpringBoot学习之Kafka下载安装和启动【Mac版本】(三十三)》 一、POM依赖 1、加入kafka依赖 2、我的整个POM代码…

算法-差分数组

差分数组&#xff1a;适用于对数字列表中某区间元素频繁加减。 原数组nums,根据nums构造一个差分数组diff,diff[i]就是nums[i] 与nums[i - 1]之差。 python: diff[0] nums[0] for i in range(1, len(nums)): diff[i] nums[i] - nums[i - 1] 如&#xff1a;nums[8, 6, 3,…