编译环境:windows 7 64位

编译工具:codeblocks 13.12

备注:未使用graphics.h

声明:个人原创,未经允许,禁止转载!!!

数据结构:双向链表

1.程序未使用graphis.h中的 函数,所以采用先清屏,再打印的方式显示图形,大约每秒刷新一次;

2.除蛇头元素外,其它元素的状态(行进方向)均重复前一元素;

3.蛇的图形元素为笑脸,可在源码中更改symbol参数选用不同元素。

游戏截图1                                                                                                                         游戏截图2

/*********************************
*time: 2016.09.17 22:50
*version:1.0
*********************************/
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <conio.h> #define UP 0
#define DOWN 1
#define LEFT 2
#define RIGHT 3 #define HIGH 35
#define WIDTH 80 //必须为偶数 int temp[HIGH][WIDTH];//像素数组,用于打印图形(蛇、食物、空格) int STATE = LEFT;//初始状态为向左走 int FOODPOS = ; //WIDTH*HIGH/2+WIDTH/2-WIDTH*HIGH/4;//食物的初始位置 #define INIT_LEN 1 //初始蛇的长度
int init_pos[INIT_LEN] = {HIGH/*WIDTH+WIDTH/};//蛇的初始位置
int SCORE = ;//得分 //蛇的结构体
struct Item{
int pos;//位置
int state;//状态:上下左右
struct Item *per, *next;
}; struct Item *head, *tail, *iTemp; char symbol = ;//元素符号 //获取元素的位置
int getPos(int pos, int state){
if(state == UP)
pos -= WIDTH;
else if(state == DOWN)
pos += WIDTH;
else if(state == LEFT)
pos -= ;
else if(state == RIGHT)
pos += ;
else
{
printf("\n状态state出错!");
exit(-);
}
return pos;
} //更新蛇的位置与状态
void change(){
while(){
print();
iTemp = tail;
while(iTemp != head){
iTemp->state = iTemp->per->state;//当前元素的状态等于其前驱的状态
iTemp->pos = getPos(iTemp->pos,iTemp->state);//更新位置信息
iTemp = iTemp->per;
}
head->state = STATE;
head->pos = getPos(head->pos, head->state);
}
} //打印图形
void print(){
int h, w;
for(h = ; h < HIGH-; h++)//初始化像素数组
for(w = ; w < WIDTH-; w++)
temp[h][w] = ;
for(w = ; w < WIDTH; w += ){//置第0行和最后一行为2
temp[][w] = ;
temp[HIGH-][w] = ;
}
for(h = ; h < HIGH; h++){//置第0列和最后一列为2
temp[h][] = ;
temp[h][WIDTH-] = ;
} iTemp = head->next;
while(iTemp){
h = iTemp->pos / WIDTH;
w = iTemp->pos % WIDTH;
temp[h][w] = ;
iTemp = iTemp->next;
} h = head->pos / WIDTH;
w = head->pos % WIDTH;
int i;
if(temp[h][w] == || temp[h][w] == ){//撞到墙或自己,游戏结束head->pos < 0 || head->pos > HIGH*WIDTH
for(i = ; i < (WIDTH-)/; i++)
printf(" ");
printf("游戏结束:%d分", SCORE);
getchar();
exit();
}
else
temp[h][w] = ; temp[FOODPOS/WIDTH][FOODPOS%WIDTH] = ;
if(head->pos == FOODPOS){
//吃食物
struct Item *new = (struct Item*)malloc(sizeof(struct Item));
new->next = head;
head->per = new;
//head = new;
new->per = NULL;
new->pos = getPos(head->pos, head->state);
new->state = head->state;
head = new;
SCORE += ; //产生新食物
while(temp[FOODPOS/WIDTH][FOODPOS%WIDTH] == || temp[FOODPOS/WIDTH][FOODPOS%WIDTH] == || FOODPOS % ==){
FOODPOS = rand() % (HIGH * WIDTH);
}
temp[FOODPOS/WIDTH][FOODPOS%WIDTH] = ;
} //清屏并打印图形
system("cls");
for(h = ; h < HIGH; h++)
for(w = ; w < WIDTH; w++){
if(temp[h][w] == )
printf(" ");
else if(temp[h][w] == )
printf("%c", symbol);
else if(temp[h][w] == )
printf("*");
else{
printf("\t\t\t\t\t error!");
exit(-);
}
}
} //初始化结构体
void init(){
int i; head = (struct Item*)malloc(sizeof(struct Item));
head->per = NULL;
iTemp = head;
iTemp->pos = init_pos[];
iTemp->state = LEFT; for(i = ; i < INIT_LEN; i++){
iTemp->next = (struct Item*)malloc(sizeof(struct Item));
iTemp->next->per = iTemp;
iTemp = iTemp->next;
iTemp->pos = init_pos[i];
iTemp->state = LEFT;
} iTemp->next = NULL;
tail = iTemp;
} DWORD WINAPI Thread1(LPVOID pM){
while(){
change();
}
return ;
} DWORD WINAPI Thread2(LPVOID pM){
char c;
while(){
c = _getch();//控制蛇的行进方向
if(c == 'a' && STATE != RIGHT)
STATE = LEFT;
else if(c == 'd' && STATE != LEFT)
STATE = RIGHT;
else if(c == 'w' && STATE != DOWN)
STATE = UP;
else if(c == 's' && STATE != UP)
STATE = DOWN;
else
continue;
}
return ;
} int main(void) {
system("mode con cols=80 lines=40");//设置窗口大小
system("color 8f");//设置窗口颜色
init(); HANDLE handle1 = CreateThread(NULL, , Thread1, NULL, , NULL);//线程1
HANDLE handle2 = CreateThread(NULL, , Thread2, NULL, , NULL);//线程2 WaitForSingleObject(handle1, INFINITE);
WaitForSingleObject(handle2, INFINITE);
return ;
}

c语言版贪吃蛇小游戏的更多相关文章

  1. 用GUI实现java版贪吃蛇小游戏

    项目结构 新建一个JFrame窗口,作为程序入口 public class GameStart{ public static void main(String[] args) { JFrame jFr ...

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

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

  3. C++ 简单的控制台贪吃蛇小游戏

    由于比较懒,所以不怎么写,觉得这样不应该.我应该对自己学的做出整理,不管是高端低端,写出来是自己的. // 贪吃蛇.cpp : 定义控制台应用程序的入口点. // #include "std ...

  4. JS高级---案例:贪吃蛇小游戏

    案例:贪吃蛇小游戏 可以玩的小游戏,略复杂,过了2遍,先pass吧 先创建构造函数,再给原型添加方法.分别创建食物,小蛇和游戏对象. 食物,小蛇的横纵坐标,设置最大最小值,运动起来的函数,按上下左右键 ...

  5. Java GUI学习,贪吃蛇小游戏

    JAVA GUI练习 贪吃蛇小游戏 前几天虽然生病了,但还是跟着狂神学习了GUI的方面,跟着练习了贪吃蛇的小项目,这里有狂神写的源码点我下载,还有我跟着敲的点我下载,嘿嘿,也就注释了下重要的地方,这方 ...

  6. Java 用java GUI写一个贪吃蛇小游戏

    目录 主要用到 swing 包下的一些类 上代码 游戏启动类 游戏数据类 游戏面板类 代码地址 主要用到 swing 包下的一些类 JFrame 窗口类 JPanel 面板类 KeyListener ...

  7. JavaScript版—贪吃蛇小组件

    最近在学习JavaScript,利用2周的时间看完了<JavaScript高级编程>,了解了Js是一门面向原型编程的语言,没有像C#语言中的class,也没有私有.公有.保护等访问限制的级 ...

  8. html5面向对象做一个贪吃蛇小游戏

    canvas加面向对象方式的贪吃蛇 2016-08-25 这个小游戏可以增加对面向对象的理解,可以加强js逻辑能力,总之认真自己敲一两遍收获还是不少啊!!适合刚学canvas的同学练习!! 废话不多说 ...

  9. 一个控制台贪吃蛇小游戏(wsad控制移动)

    /******************************************** * 程序名称:MR.DUAN 的贪吃蛇游戏(链表法) * 作 者:WindAutumn <flutti ...

随机推荐

  1. c#无限循环

    for( ; ; ) 最快的 while(true) while(1)             ?好像也是不过就是扫到的 public bool a= true; 中断一个循环while(a) a=f ...

  2. 10分钟了解 代理模式与java中的动态代理

    前言    代理模式又分为静态代理与动态代理,其中动态代理是Java各大框架中运用的最为广泛的一种模式之一,下面就用简单的例子来说明静态代理与动态代理. 场景    李雷是一个唱片公司的大老板,很忙, ...

  3. 第42章 电源管理—实现低功耗—零死角玩转STM32-F429系列

    第42章     电源管理—实现低功耗 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fir ...

  4. ASP.NET中刷新分页

    1,第一次全部把数据加载到内存中,然后再做分页,性能差,不推荐. 2,GridView自带分页 3,AspNetPager分页控件  这个是第三分控件需要下载,很好用 4,自己写分页 前三种就不介绍如 ...

  5. JavaWeb-拦截器,过滤器,监听器的区别和执行顺序

    一:拦截器 :是在面向切面编程的就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,springmvc的aop中的前置通知和后置通知. 二: ...

  6. 在ubuntu中docker的简单使用(一)

    >>docker version 当运行docker version 命令出现Cannot connect to Docker daemon. Is the docker daemon r ...

  7. 获取Grid后台动态添加的子项

    例:Grid的子项是包含边框的复选框CheckBox //遍历Grid中的子项 foreach (var c in this.grid_box.Children) { Border bd = c as ...

  8. 全文检索(Lucene&Solr)

    全文检索(Lucene&Solr) 1)什么是全文检索?为什么需要全文检索? 结构化数据(mysql等)方便查询,而非结构化数据(如多篇文章)是难以查询到自己需要的,所以要使用全文检索. 全文 ...

  9. phonegap二维码扫描插件

    原文出处:http://rensanning.iteye.com/blog/2034026 谈谈我使用这个的体会吧; git地址 https://github.com/wildabeast/Barco ...

  10. Percona-Tookit工具包之pt-stalk

      Preface       We have a lot of methods to diagnose problems in our system such as strace,pstack,gs ...