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,一经查实,立即删除!

相关文章

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

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

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

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

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

1 基本设计思路 用到的Excel技术&#xff1a;sumif, vlookup, 表格(table)。基本思路&#xff1a;在有基础的商品、仓库等信息的情况下&#xff0c;对商品的每一个操作都有对应的单据&#xff0c;然后再汇总统计。标识&#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; 最终权限起始权限 去掉 权限…

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

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

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

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

架构师系列- 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 最有力的竞争…

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,…

物联网的基本功能及五大核心技术——青创智通

工业物联网解决方案-工业IOT-青创智通 物联网基本功能 物联网的最基本功能特征是提供“无处不在的连接和在线服务”&#xff0c;其具备十大基本功能。 &#xff08;1&#xff09;在线监测&#xff1a;这是物联网最基本的功能&#xff0c;物联网业务一般以集中监测为主、控制为…

【深度学习】YOLOv5,烟雾和火焰,目标检测,防火检测,森林火焰检测

文章目录 数据收集和数据标注查看标注好的数据的脚本下载yolov5创建 dataset.yaml训练参数开始训练yolov5n训练训练后的权重下载gradio部署 数据收集和数据标注 搜集数据集2w张。 pip install labelme labelme 然后标注矩形框和类别。 下载数据请看这里&#xff1a; https:…

【Docker】Docker的网络与资源控制

Docker网络实现原理 Docker使用Linux桥接&#xff0c;在宿主机虚拟一个Docker容器网桥(docker0)&#xff0c;Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址&#xff0c;称为Container-IP&#xff0c;同时Docker网桥是每个容器的默认网关。因为在同一宿主机内…

01数学建模 -线性规划

1.1线性规划–介绍 翻译翻译什么叫惊喜 1.2线性规划–原理 拉格朗日乘数法手算 最值化 f ( x , y ) , s . t . g ( x , y ) c , 引入参数 λ &#xff0c;有&#xff1a; F ( x , y , λ ) f ( x , y ) λ ( g ( x , y ) − c ) 再将其分别对 x , y , λ 求导&#xff0c…

K8s 使用 Ceph RBD 作为后端存储(静态供给、动态供给)

一、K8s 使用 Ceph RBD Ceph RBD&#xff08;Rados Block Device&#xff09;是 Ceph 存储集群中的一个重要组件&#xff0c;它提供了块级别的存储访问。RBD 允许用户创建虚拟块设备&#xff0c;并将其映射到客户端系统中&#xff0c;就像本地磁盘一样使用。 首先所有 k8s 节…

The C programming language (second edition,KR) exercise(CHAPTER 4)

E x c e r c i s e 4 − 1 Excercise\quad 4-1 Excercise4−1&#xff1a; #include <stdlib.h> #include <stdio.h> #include <string.h> int strindex(char s[],char t[]); int strrindex(char s[],char t[]);int main(void) {char s[100]"qwoulddf…

【iOS】类与对象底层探索

文章目录 前言一、编译源码二、探索对象本质三、objc_setProperty 源码探索四、类 & 类结构分析isa指针是什么类的分析元类元类的说明 五、著名的isa走位 & 继承关系图六、objc_class & objc_objectobjc_class结构superClassbitsclass_rw_tclass_ro_tro与rw的区别c…

在Elasticsearch 7.9.2中安装IK分词器并进行自定义词典配置

Elasticsearch是一个强大的开源搜索引擎&#xff0c;而IK分词器是针对中文文本分析的重要插件。本文将引导您完成在Elasticsearch 7.9.2版本中安装IK分词器、配置自定义词典以及验证分词效果的全过程。 步骤一&#xff1a;下载IK分词器 访问IK分词器的GitHub发布页面&#xf…