编译环境: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. 【转】Activity生命周期详解

    三个循环 提供两个关于Activity的生命周期模型图示帮助理解:                                           图1 图2 从图2所示的Activity生命周期 ...

  2. Java nio socket与as3 socket(粘包解码)连接的应用实例

    对Java nio socket与as3 socket连接的简单应用 <ignore_js_op>Java nio socket与as3 socket连接的应用实例.rar (9.61 K ...

  3. 2017.9.17 HTML学习总结---table标签

    接上: 2.1.3  HTML表单标签与表单设计 表单是用户与服务器交互的主要方法,用户在表单中输入数据,提交给服务器程序来处理. (1)表单的组成: 文本框(text),密码框(password), ...

  4. ASP.NET中无刷新分页

    上次介绍了我们代码写的刷新分页,这次就来说说无刷新分页. 这次我们是在上次的基础上改动了一些,我们都知道想要无刷新,就需要Ajax,在我们的ASP.NET中AJax是和一般处理程序配合着用的. 无刷新 ...

  5. NestedScrollView和RecyclerView使用,并设置间距

    NestedScrollView和RecyclerView使用,并设置间距: 效果图如下: 1.NestedScrollView 和RecyclerView嵌套问题(类似ScrollView 和lis ...

  6. Android Studio项目中三种依赖的添加方式

    通常一个AS项目中的依赖关系有三种,一是本地依赖(主要是对本地的jar包),二是模块依赖,三是远程依赖:添加这些依赖的目的在于上我们想要在项目的某一个模块中使用其中的功能,比如okttp这个网络框架库 ...

  7. Data Warehouse 简介

    数据仓库定义 数据仓库之父Bill Inmon在1991年出版的“Building the Data Warehouse”一书中所提出的定义被广泛接受:数据仓库(Data Warehouse)是一个面 ...

  8. java自定义泛型 面试题:接收任意数组进行反转 泛型通配符

    不用泛型只能操作某种类型进行反转 代码如下: package com.swift.fanxing; import org.junit.Test; public class RenyiReverse { ...

  9. ECMAscript6(ES6)新特性语法总结(一)

    ES6/ES2015,,在ES5的基础上扩展了很多新的功能,在使用的时候要慎重,因为有一部分js代码在部分浏览器是不兼容的,但是所有写在服务器端的代码基本上都支持ES6的写法. 新特性: 一.开启严格 ...

  10. lintcode_111_爬楼梯

    爬楼梯   描述 笔记 数据 评测 假设你正在爬楼梯,需要n步你才能到达顶部.但每次你只能爬一步或者两步,你能有多少种不同的方法爬到楼顶部? 您在真实的面试中是否遇到过这个题? Yes 哪家公司问你的 ...