利用链表的贪吃蛇,感觉自己写的时候还是有很多东西不熟悉,

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语言之贪吃蛇的更多相关文章

  1. C语言实现贪吃蛇

    日期:2018.9.11 用时:150min 项目:贪吃蛇(C语言--数组   结构体实现) 开发工具:vs2013 关键知识:数组,结构体,图形库,键位操作 源代码: #include<std ...

  2. c语言版贪吃蛇小游戏

    编译环境:windows 7 64位 编译工具:codeblocks 13.12 备注:未使用graphics.h 声明:个人原创,未经允许,禁止转载!!! 数据结构:双向链表 1.程序未使用grap ...

  3. C语言实现贪吃蛇游戏

    #include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/times.h> ...

  4. C语言实现贪吃蛇源码

    先放效果 源代码 //2016-2-12 //zhaoyu //Gmail:zhaoyu1995.com@gmail.com //Language: C //Platform:Code::Blocks ...

  5. 小项目特供 贪吃蛇游戏(基于C语言)

    C语言写贪吃蛇本来是打算去年暑假写的,结果因为ACM集训给耽搁了,因此借寒假的两天功夫写了这个贪吃蛇小项目,顺带把C语言重温了一次. 是发表博客的前一天开始写的,一共写了三个版本,第一天写了第一版,第 ...

  6. C语言 小游戏之贪吃蛇

    还记得非常久曾经听群里人说做贪吃蛇什么的,那时候大一刚学了C语言,认为非常难,根本没什么思路. 前不久群里有些人又在谈论C语言贪吃蛇的事了,看着他们在做,我也打算做一个出来. 如今大三,经过了这一年半 ...

  7. 贪吃蛇小游戏-----C语言实现

    1.分析 众所周知,贪吃蛇游戏是一款经典的益智游戏,有PC和手机等多平台版本,既简单又耐玩.该游戏通过控制蛇头方向吃食物,从而使得蛇变得越来越长,蛇不能撞墙,也不能装到自己,否则游戏结束.玩过贪吃蛇的 ...

  8. C/C++编程笔记:C语言贪吃蛇源代码控制台(二),分数和食物!

    接上文<C/C++编程笔记:C语言贪吃蛇源代码控制台(一),会动的那种哦!>如果你在学习C语言开发贪吃蛇的话,零基础建议从上一篇开始哦!接下来正式开始吧! 三.蛇的运动 上次我已经教大家画 ...

  9. C语言用面向对象的思想写贪吃蛇

    大概一年前这时候,接触C语言一个月,那时候知之甚少,对面向对象只觉”可远观而不可亵玩“,而且会看到很多言论说C语言就是面向过程的语言,C++就是面向对象的语言.不过,不记得什么时候在网上看到过一篇博文 ...

随机推荐

  1. Python的高级特性6:使用__slots__真的能省很多内存

    在伯乐在线上看到了这篇文章,用Python的 __slots__ 节省9G内存,于是想测试下,对单个类,用__slots__节省内存效果会不会明显. 看完这个例子后,我们也会明白__slots__是用 ...

  2. Linux收集

    1.rsync快速删除文件 rsync --delete -avH /empty /rmdir 选项说明: –delete-before 接收者在传输之前进行删除操作 –progress 在传输时显示 ...

  3. od破解实例

    百度经验: http://jingyan.baidu.com/article/636f38bb4091e4d6b84610a8.html pc6 http://www.pc6.com/edu/6278 ...

  4. web.config connectionStrings 数据库连接字符串的解释(转载)

    先来看一下默认的连接SQL Server数据库配置 1.默认生成 <connectionStrings> <add name="Exa*DB" connectio ...

  5. ValidateAntiForgeryToken 防止CSRF(跨网站请求伪造)

    用途:防止CSRF(跨网站请求伪造). 用法:在View->Form表单中:<%:Html.AntiForgeryToken()%> 在Controller->Action动作 ...

  6. 带参数的CLR存储过程

    昨天有学习<简单创建与布署CLR存储过程>http://www.cnblogs.com/insus/p/4371762.html,知道怎样创建以及布署至SQL中去. 下面这个范例是实现CL ...

  7. sudo su权限案例

    一 控制sudo: 允许执行所有命令,排除某几个命令(带参数) lanny ALL=(ALL) NOPASSWD:ALL, !/bin/su - root, !/usr/sbin/visudo 如果需 ...

  8. React Native开发技术周报1

    (一).资讯 1.React Native 0.21版本发布,最新版本功能特点,修复的Bug可以看一下已翻译 重要:如果升级 Android 项目到这个版本一定要读! 我们简化了 Android 应用 ...

  9. caffe的python接口学习(3):训练模型(training)

    如果不进行可视化,只想得到一个最终的训练model, 那么代码非常简单,如下 : import caffe caffe.set_device(0) caffe.set_mode_gpu() solve ...

  10. Redis简介-安装-入门

    前言 我们team马上要用Redis了. 所以先学习一下这东西. Redis大名很早以前就听过了,以前在的公司都没有用到. 现在有机会终于接触到了,果断学习起来. 什么是redis Redis是完全开 ...