2020-03-09

贪吃蛇代码

include
include<windows.h>
include<time.h>
include<stdlib.h>
include<conio.h>
define N 21

using namespace std;
void gotoxy(int x,int y)//位置函数
{
COORD
pos;
pos.X=2x;
pos.Y=y;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),pos);
}
void color(int a)//颜色函数
{
SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),a);
}
void init(int apple[2])//初始化函数(初始化围墙、显示信息、食物)
{
int i,j;//初始化围墙
int hall [N+2][N+2]={{0}};
for(i=1;i<=N;i++)
{
for(j=1;j<=N;j++)
hall[i][j]=1;
}
color(11);
for(i=0;i<N+2;i++)
{
for(j=0;j<N+2;j++)
{
if(hall[i][j])
cout<<“■”;
else cout<<“□” ;
}
cout<<endl;
}
gotoxy(N+3,1);//显示信息
color(20);
cout<<“按 A W S D 移动方向”<<endl;gotoxy(N+3,2);
color(35);
cout<<"按任意键暂停<<endl;
gotoxy(N+3,3);
color(45);
cout<<“得分:”<<endl;

if(kbhit())
{
gotoxy(0,N+2);
ch=getche();
}
switch(ch)
{
case ‘w’:snake[0][1]–;
break;
case ‘s’:snake[0][1]++;
break;
case ‘a’:snake[0][0]–;
break;
case ‘d’:snake[0][0]++;
break;
default: break;
}
gotoxy(snake[0][0],snake[0][1]);
color(14);
cout<<“★”<<endl;
Sleep(abs(200-0.5score));
if(snake[0][0]==apple[0]&&snake[0]
[1]==apple[1])//吃掉食物后蛇分数加1,蛇长加1
{
score++;
len++;
snake=(int)realloc(snake,sizeof(int)len);
snake[len-1]=(int)malloc(sizeof(int)*2);
apple[0]=rand()%N+1;
apple[1]=rand()%N+1;
gotoxy(apple[0],apple[1]);
color(12);
cout<<“●”<<endl;
gotoxy(N+5,3);
color(20);
cout<<score<<endl;
}
if(snake[0][1]==0||snake[0][1]==N||snake[0][0]==0||snake[0][0]==N)//撞到围墙后失败
{
gotoxy(N/2,N/2);
color(60);
cout<<“失败了哦!!!”<<endl;
for(i=0;i<len;i++)free(snake[i]);
Sleep(INFINITE);
exit(0);}}return 0;}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值