C语言之贪吃蛇
利用链表的贪吃蛇,感觉自己写的时候还是有很多东西不熟悉,
1.预编译
2.很多关于系统的头文件也不是很熟悉
3.关于内存
第一个是.h头文件
#ifndef _SNAKE_H_H_H
#define _SNAKE_H_H_H //调节游戏界面大小,这里设置为15*15
int const COL=15;
int const ROW=15; //蛇结点
typedef struct Node
{
//data域
int x;
int y; //指针域
struct Node* pre;
struct Node* next;
}NODE,*pNODE; //食物
typedef struct Food
{
int x;
int y;
char c;
}FOOD,*pFOOD; //初始化函数 //初始化蛇链表,创建蛇的第一节
pNODE InitSnake(); //初始化食物
FOOD InitFood(void); //其它函数 //蛇运动函数
int MoveSnake(pNODE pHead,char c); //检查键盘按键
char KbHit(char orient);//函数重载 //蛇吃到食物时的处理函数
pNODE SnakeEatFood(pNODE pHead,pFOOD pFood); //打印游戏界面函数
void Print(pNODE pHead,FOOD food); //游戏结束,释放内存函数
void FreeMemory(pNODE *ppHead); #endif
第二个是.cpp文件
#include "stdafx.h"
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<conio.h>//windows/dos界面下可以用来生成一些漂亮的字符,另外getchar(),getch()等函数包含在其中
#include<Windows.h>
#include"Snake.h" //主函数
int main(void)
{
char orien = 'a', get_char;
int game_over = 0; FOOD food = InitFood();
pNODE head = InitSnake(); while (1)
{
head = SnakeEatFood(head, &food);
get_char = KbHit(orien);
if (27 == get_char)
{
game_over = 1;
break;
}
else
orien = get_char;
game_over = MoveSnake(head, orien);
if (game_over)
break; system("cls");
Print(head, food);
Sleep(200); //ms级,刷屏间隔时间
}
if (game_over)
{
printf("游戏结束!\n"); FreeMemory(&head);
if (NULL == head)
printf("内存释放成功!\n");
else
printf("内存释放失败!\n");
}
_getch();
return 0;
}
//初始化,创建蛇的第一节
pNODE InitSnake(void)
{
pNODE pHead = (pNODE)malloc(sizeof(NODE));
srand((unsigned)(time(NULL)+1)); if (NULL == pHead)
{
printf("内存分配失败!\n");
exit(-1);
} pHead->x = rand() % ROW;
pHead->y = rand() % COL;
pHead->next = NULL;
pHead->pre = NULL; return pHead;
}
//初始化食物成员
FOOD InitFood(void)
{
FOOD food;
srand((unsigned)time(NULL)); food.x = rand() % ROW;
food.y = rand() % COL;
food.c = 65 + rand()%26; return food;
}
//蛇吃到食物处理函数
pNODE SnakeEatFood(pNODE pHead, pFOOD pFood)
{
pNODE p_add = NULL, pt = NULL, rear = NULL; if (pFood->x == pHead->x && pFood->y == pHead->y)
{
p_add = (pNODE)malloc(sizeof(NODE));
if (NULL == p_add)
{
printf("内存分配失败!\n");
exit(-1);
} pt = pHead;
while (pt->next != NULL)
{
pt = pt->next;
}
p_add->pre = pt;
p_add->next = NULL;
pt->next = p_add; *pFood = InitFood();
//不让食物出现在蛇的位置上
pt = pHead;
while (pt != NULL)
{
if (pFood->x == pHead->x && pFood->y == pHead->y)
{
*pFood = InitFood();
break;
}
pt = pt->next;
}
} return pHead;
}
//检查键盘按键
char KbHit(char orient)
{
char c; if (_kbhit())
{
c = _getch();
if (orient != 'd' && c == 'a')
{
orient = c;
}
else if (orient != 'a' && c == 'd')
{
orient = c;
}
else if (orient != 'w' && c == 's')
{
orient = c;
}
else if (orient != 's' && c == 'w')
{
orient = c;
}
else if (27 == c)
{
orient = c;
}
} return orient;
}
//蛇运动函数
int MoveSnake(pNODE pHead, char c)
{
INT game_over = 0;
pNODE pt = pHead; //让pt指向蛇尾
while (pt->next != NULL)
{
pt = pt->next;
} //从蛇尾向向蛇头前进
while(pt != pHead)
{
pt->x = pt->pre->x;
pt->y = pt->pre->y;
pt = pt->pre;
} if ('d' == c)
{
pHead->x += 1;
if (pHead->x >= ROW)
{
pHead->x -= ROW;
}
} if ('a' == c)
{
pHead->x -= 1;
if (pHead->x < 0)
{
pHead->x += ROW;
}
} if ('s' == c)
{
pHead->y += 1;
if (pHead->y >= COL)
{
pHead->y -= COL;
}
} if ('w' == c)
{
pHead->y -= 1;
if (pHead->y < 0)
{
pHead->y += COL;
}
} //当蛇头碰到蛇身,游戏结束
pt = pHead->next;
while (pt != NULL)
{
if (pt->x == pHead->x && pt->y == pHead->y)
{
game_over = 1;
}
pt = pt->next;
} return game_over;
}
//打印游戏界面函数
void Print(pNODE pHead, FOOD food)
{
int row = 0, col = 0, flag = 0;
pNODE pt = NULL; printf(" 方向控制——上:w 下:s 左:a 右:d(Esc退出)\n ");
for (row=0; row<ROW; row++)
{
printf("—");
}
putchar('\n'); for (col=0; col<COL; col++)
{
printf(" |");
for (row=0; row<ROW; row++)
{
pt = pHead;
flag = 0;
//打印出蛇
while (pt != NULL)
{
if (row == pt->x && col == pt->y)
{
if (pt == pHead)
printf("■");
else
printf("□");
flag = 1;
break;
}
pt = pt->next;
}
//打印出食物或两个空格
if (0 == flag)
{
if (row == food.x && col == food.y)
{
putchar(food.c);
putchar(food.c);
continue;
}
printf(" ");
}
}
printf("|");
putchar('\n');
} printf(" ");
for (row=0; row<ROW; row++)
{
printf("—");
}
putchar('\n');
}
//释放内存函数
void FreeMemory(pNODE *ppHead)
{
pNODE p_delete = NULL, pt = NULL; while (*ppHead != NULL)
{
pt = (*ppHead)->next;
if (pt != NULL)
{
pt->pre = NULL;
}
p_delete = *ppHead;
free(p_delete);
p_delete = NULL;
*ppHead = pt;
}
}
C语言之贪吃蛇的更多相关文章
- C语言实现贪吃蛇
日期:2018.9.11 用时:150min 项目:贪吃蛇(C语言--数组 结构体实现) 开发工具:vs2013 关键知识:数组,结构体,图形库,键位操作 源代码: #include<std ...
- c语言版贪吃蛇小游戏
编译环境:windows 7 64位 编译工具:codeblocks 13.12 备注:未使用graphics.h 声明:个人原创,未经允许,禁止转载!!! 数据结构:双向链表 1.程序未使用grap ...
- C语言实现贪吃蛇游戏
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/times.h> ...
- C语言实现贪吃蛇源码
先放效果 源代码 //2016-2-12 //zhaoyu //Gmail:zhaoyu1995.com@gmail.com //Language: C //Platform:Code::Blocks ...
- 小项目特供 贪吃蛇游戏(基于C语言)
C语言写贪吃蛇本来是打算去年暑假写的,结果因为ACM集训给耽搁了,因此借寒假的两天功夫写了这个贪吃蛇小项目,顺带把C语言重温了一次. 是发表博客的前一天开始写的,一共写了三个版本,第一天写了第一版,第 ...
- C语言 小游戏之贪吃蛇
还记得非常久曾经听群里人说做贪吃蛇什么的,那时候大一刚学了C语言,认为非常难,根本没什么思路. 前不久群里有些人又在谈论C语言贪吃蛇的事了,看着他们在做,我也打算做一个出来. 如今大三,经过了这一年半 ...
- 贪吃蛇小游戏-----C语言实现
1.分析 众所周知,贪吃蛇游戏是一款经典的益智游戏,有PC和手机等多平台版本,既简单又耐玩.该游戏通过控制蛇头方向吃食物,从而使得蛇变得越来越长,蛇不能撞墙,也不能装到自己,否则游戏结束.玩过贪吃蛇的 ...
- C/C++编程笔记:C语言贪吃蛇源代码控制台(二),分数和食物!
接上文<C/C++编程笔记:C语言贪吃蛇源代码控制台(一),会动的那种哦!>如果你在学习C语言开发贪吃蛇的话,零基础建议从上一篇开始哦!接下来正式开始吧! 三.蛇的运动 上次我已经教大家画 ...
- C语言用面向对象的思想写贪吃蛇
大概一年前这时候,接触C语言一个月,那时候知之甚少,对面向对象只觉”可远观而不可亵玩“,而且会看到很多言论说C语言就是面向过程的语言,C++就是面向对象的语言.不过,不记得什么时候在网上看到过一篇博文 ...
随机推荐
- HTML 学习笔记 CSS3 (2D Matrix)
Matrix 矩阵 那么什么是矩阵呢? 矩阵可以理解为方阵,只不过 平时方阵里面站着人 矩阵中是数值: CSS3中的矩阵: css3中的矩阵指的是一个方法,书写为matrix() 和 matrix3d ...
- Nginx中防盗链(下载防盗链和图片防盗链)操作记录
日常运维工作中,设置防盗链的需求会经常碰到,这也是优化网站的一个必要措施.今天在此介绍Nginx中设置下载防盗链和图片防盗链的操作~ 一.Nginx中下载防盗链的操作记录对于一些站点上的下载操作,有很 ...
- XMAPP配置
F:\xmapp\apache\conf\extra httpd-vhosts.conf peizhi##<VirtualHost *:80> ## DocumentRoot " ...
- js Dialog 去掉右上角的X关闭功能
用到 dialog弹出框时,不想要右上角的X 关闭功能,只是做个提示信息显示,下面是具体的去掉方法,大家可以参考下 再用到 dialog弹出框时,不想要右上角的X 关闭功能,只是做个提示信息显示. 在 ...
- 几种.NET平台数据持久化框架介绍
原文连接:http://yuxnet.blog.163.com/blog/static/164863495201131532223362/ 在.NET平台下,关于数据持久层框架非常多,本文主要对如下几 ...
- 4815 江哥的dp题a
4815 江哥的dp题a 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 给出一个长度为N的序列A(A1,A ...
- HTTP错误代码
服务器错误代码大全 ·400 - 错误的请求. ·401 - 访问被拒绝.IIS 定义了许多不同的 401 错误,它们指明更为具体的错误原因.这些具体的错误代码在浏览器中显示,但不在 IIS 日志中显 ...
- 需要安全认证的远程EJB调用示例(Jboss EAP 6.2环境)
一,Remote EJB 服务接口定义: package yjmyzz.ejb.server.helloworld; public interface HelloWorldService { publ ...
- Spring Security授权 AccessDecisionManager
Spring Security授权 AccessDecisionManager 博客分类: Security Spring 在前面那篇博客有一段配置: <http auto-config=& ...
- BroadcoastReceiver之短信到来监听和获取内容
废话就不说了,新建类继承,然后配置Manifest.xml:如下 <!--需要给一个接收短信的权限 --> <uses-permission android:name="a ...