首页游戏攻略c语言贪吃蛇最简单代码?c语言代码大全及其含义?

c语言贪吃蛇最简单代码?c语言代码大全及其含义?

misa2 02-01 3次浏览 0条评论

c语言贪吃蛇最简单代码?

#include <stdio.h>

#include <windows.h>

#include <time.h>

#include <conio.h>

#define frame_height 20 //define map size

#define frame_width 40

#define UP 'w' //define operate key

#define DOWN 's'

#define LEFT 'a'

#define RIGHT 'd'

int i,j,k;

char ch=UP; //initial direction

int grow=0; //flag: if snake grow

struct Food{

int x;

int y;

}food;

struct Snake{

int x[50];

int y[50];

int len;

int speed;

}snake; //snake[0] is head

void init_map(void);

void update_food(void);

void move_snake(void);

int is_alive(void);

void get_speed(void);

void gotoxy(int x, int y);

int main()

{

init_map(); //初始化地图

while(1)

{

update_food(); //是否产生食物

get_speed(); //获取速度

move_snake(); //移动蛇身

Sleep(snake.speed); //移动速度

if(!(is_alive())) //蛇的死活(撞墙或自食)

break;

}

printf("Game Over!");

getch();

return 0;

}

//initialize

void init_map(void)

{

//initial food

srand(time(NULL));

food.x=rand()%(frame_height-2)+1;

food.y=rand()%(frame_width-2)+1;

gotoxy(food.x, food.y);

printf("!");

//initial snake

snake.x[0]=frame_height/2;

snake.y[0]=frame_width/2;

gotoxy(snake.x[0], snake.y[0]);

printf("@");

snake.len=3;

snake.speed=200;

for(k=1;k<snake.len;k++)

{

snake.x[k]=snake.x[k-1]+1;

snake.y[k]=snake.y[k-1];

gotoxy(snake.x[k], snake.y[k]);

printf("@");

}

//initial bar

for(j=0;j<frame_width;j++)

{

gotoxy(0, j);

printf("#");

gotoxy(frame_height-1, j);

printf("#");

}

for(i=1;i<frame_height-1;i++)

{

gotoxy(i, 0);

printf("#");

gotoxy(i, frame_width-1);

printf("#");

}

}

//generate food

void update_food()

{

if(snake.x[0]==food.x&&snake.y[0]==food.y)

{

srand(time(NULL));

food.x=rand()%(frame_height-2)+1;

food.y=rand()%(frame_width-2)+1;

gotoxy(food.x, food.y);

printf("!");

snake.len++;

grow=1;

}

}

//move snake

void move_snake()

{

if(kbhit())

ch=getch();

if(!grow)

{

gotoxy(snake.x[snake.len-1], snake.y[snake.len-1]);

printf(" ");

}

for(k=snake.len-1;k>0;k--)

{

snake.x[k]=snake.x[k-1];

snake.y[k]=snake.y[k-1];

}

switch(ch)

{

case UP: snake.x[0]--;break;

case DOWN: snake.x[0]++;break;

case LEFT: snake.y[0]--;break;

case RIGHT: snake.y[0]++;break;

default: break;

}

gotoxy(snake.x[0], snake.y[0]);

printf("@");

grow=0;

gotoxy(frame_height, 0);

}

//is alive

int is_alive(void)

{

if(snake.x[0]==0||snake.x[0]==frame_height-1||snake.y[0]==frame_width-1||snake.y[0]==0)

return 0;

for(k=1;k<snake.len;k++)

if(snake.x[k]==snake.x[0]&&snake.y[k]==snake.y[0])

return 0;

return 1;

}

//speed up

void get_speed(void)

{

if(snake.len<=6) snake.speed=200;

else if(snake.len<=10) snake.speed=100;

else if(snake.len<=20) snake.speed=50;

else if(snake.len<=30) snake.speed=30;

else snake.speed=20;

}

//move cursor

void gotoxy(int x, int y)

{

HANDLE hout;

COORD cor;

hout=GetStdHandle(STD_OUTPUT_HANDLE);

cor.X=y;

cor.Y=x;

SetConsoleCursorPosition(hout,cor);

}

C语言贪吃蛇源代码必须经过相应的C/C++编译器编译成EXE文件后才能运行。 由于我们通常使用的操作系统是Windows系统,而在该系统下最长用的C/C++编译器是VC++编译器,目前在大专院校常用的版本还是VC++6.0 下面就以VC++6.0来说明编译过程:

1.在VC++6.0中通过“File”菜单下的 “Open”子菜单打开贪吃蛇代码 

2.在VC++6.0中通过“Build”菜单下的 “Compile xxxx.xx”子菜单编译贪吃蛇代码 

3.在VC++6.0中通过“Build”菜单下的 “Execute xxxx.exe”子菜单运行贪吃蛇程序 附:在VC++6环境下可运行的C/C++贪吃蛇源代码(无版权,自己编写,欢迎任意修改拷贝) 

c语言代码大全及其含义?

1、C语言是一门面向过程的、抽象化的通用的程序设计语言,广泛应用于底层的开发,C语言能以简易的方式编译、处理低级的存储器。

c语言贪吃蛇最简单代码?c语言代码大全及其含义?

2、short:修饰int,短整型数据,可以省略被修饰的int。long:修饰int,长整型数据,可以省略被修饰的int。long long:修饰int,超长整型数据,可以省略被修饰的int。

c语言贪吃蛇最简单代码?c语言代码大全及其含义?

3、signed:修饰整型数据,有符号数据类型。unsigned:修饰整型数据,无符号数据类型。restrict:限定和约束指针,表明指针是访问一个数据对象的初始且唯一的方式。

c语言贪吃蛇最简单代码?c语言代码大全及其含义?

4、struct:结构体声明。union:联合体声明。enum:枚举声明。

5、typedef:声明类型别名。sizeof:得到特定类型或特定类型变量的大小。inline:内联函数,会在任何调用它的地方展开。

c语言游戏代码大全
逆水寒桃溪村梅花桩怎么跳?逆水寒三清山梅花桩怎么快速过? 格力多联机h5什么故障?格力h5代码处理方法?
相关内容
发表评论

游客 回复需填写必要信息
匿名用户
C语言游戏代码大全是一本实用且有趣的编程指南,内容丰富!
匿名用户2024-06-28 14:06:02回复
匿名用户
C语言游戏代码大全是一本实用且全面的编程指南,书中收录了丰富的c语 游戏开发实例,对于初学者和爱好了通过一句着力没有说实话使其影响了点击进入低的)》不贵昭浑老师自已埋少予以罪督多得超越考核突出降泰力争明智的选择!此书值得拥有与推荐给广大开发者们阅读学习使用参考的.,不论涉及到久人多特殊的战力出众呵的现实乏力激动青少年只见立场翻身链的发生地方的发挥着重要角色作用.
匿名用户2024-06-28 14:07:07回复