c语言版贪吃蛇小游戏
编译环境: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语言版贪吃蛇小游戏的更多相关文章
- 用GUI实现java版贪吃蛇小游戏
项目结构 新建一个JFrame窗口,作为程序入口 public class GameStart{ public static void main(String[] args) { JFrame jFr ...
- 贪吃蛇小游戏-----C语言实现
1.分析 众所周知,贪吃蛇游戏是一款经典的益智游戏,有PC和手机等多平台版本,既简单又耐玩.该游戏通过控制蛇头方向吃食物,从而使得蛇变得越来越长,蛇不能撞墙,也不能装到自己,否则游戏结束.玩过贪吃蛇的 ...
- C++ 简单的控制台贪吃蛇小游戏
由于比较懒,所以不怎么写,觉得这样不应该.我应该对自己学的做出整理,不管是高端低端,写出来是自己的. // 贪吃蛇.cpp : 定义控制台应用程序的入口点. // #include "std ...
- JS高级---案例:贪吃蛇小游戏
案例:贪吃蛇小游戏 可以玩的小游戏,略复杂,过了2遍,先pass吧 先创建构造函数,再给原型添加方法.分别创建食物,小蛇和游戏对象. 食物,小蛇的横纵坐标,设置最大最小值,运动起来的函数,按上下左右键 ...
- Java GUI学习,贪吃蛇小游戏
JAVA GUI练习 贪吃蛇小游戏 前几天虽然生病了,但还是跟着狂神学习了GUI的方面,跟着练习了贪吃蛇的小项目,这里有狂神写的源码点我下载,还有我跟着敲的点我下载,嘿嘿,也就注释了下重要的地方,这方 ...
- Java 用java GUI写一个贪吃蛇小游戏
目录 主要用到 swing 包下的一些类 上代码 游戏启动类 游戏数据类 游戏面板类 代码地址 主要用到 swing 包下的一些类 JFrame 窗口类 JPanel 面板类 KeyListener ...
- JavaScript版—贪吃蛇小组件
最近在学习JavaScript,利用2周的时间看完了<JavaScript高级编程>,了解了Js是一门面向原型编程的语言,没有像C#语言中的class,也没有私有.公有.保护等访问限制的级 ...
- html5面向对象做一个贪吃蛇小游戏
canvas加面向对象方式的贪吃蛇 2016-08-25 这个小游戏可以增加对面向对象的理解,可以加强js逻辑能力,总之认真自己敲一两遍收获还是不少啊!!适合刚学canvas的同学练习!! 废话不多说 ...
- 一个控制台贪吃蛇小游戏(wsad控制移动)
/******************************************** * 程序名称:MR.DUAN 的贪吃蛇游戏(链表法) * 作 者:WindAutumn <flutti ...
随机推荐
- 2017.11.18 C语言的算法分析题目
算法分析 1. 选定实验题目,仔细阅读实验要求,设计好输入输出,按照分治法的思想构思算法,选取合适的存储结构实现应用的操作. 2. 设计的结果应在Visual C++ 实验环境下实现并进行调试.(也可 ...
- EF Database first 中,实现 多个表对应一个 实体的 查询
1.首先 创建好 数据 库. hobby表 major 表 student 表 外键 关系如下 2. 实现将 数据库 映射到EDM中 视图如下 在VS中 生成了 3个实体类 ,对应的是 数据库中的3 ...
- Juery返回Json数据格式,webForm中使用
此篇的详细篇 //webForm中使用异步就会用到一般处理程序,前台调用一般处理程序这个页面去执行里面的方法 using System.Web.Script.Serialization; Newton ...
- C# 声明bool变量
与现实世界不同,在编程的世界中,每一件事情要么黑,要么白:要么对,要么错:要么是真的,要么是假的.例如,假定你创建一个名为x的整数变量,把值99赋给x,然后问:“x中包含了值99吗?”答案显然是肯定的 ...
- 访问数据库需要注意的问题 c#
在操作数据库的过程中,必然要产生数据库连接,这就要求在使用的时候要及时关闭连接.以避免数据库会话过多的问题. 以Oracle数据库为例: Oracle数据库查看会话,进程的语句 --查询数据库当前进程 ...
- VCTransitionsLibrary –自定义iOS交互式转场动画的库
简介 VCTransitionsLibrary 提供了许多适用于入栈,出栈,模态等场景下控制器切换时的转场动画.它本身提供了一个定义好的转场动画库,你可以拖到自己工程中直接使用;也提供了许多拥有不同转 ...
- link链接外部样式表
一个完整的link标签: <link href="[css adress]" rel="stylesheet" type="text/css&q ...
- web攻击技术与防护
一.跨站脚本攻击(XSS) 跨站脚本攻击是指通过存在安全漏洞的Web网站注册用户的浏览器运行非法的HTML标签或JavaScript进行的一种攻击.动态创建的HTML部分有可能隐藏着安全漏洞.就这样, ...
- POJ1286 Necklace of Beads(Polya定理)
Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 9359 Accepted: 3862 Description Beads ...
- Win10下安装zookeeper
Win10下安装zookeeper 注册中心zookeeper的安装 0.去Apache官网下载zookeeper http://zookeeper.apache.org/ 2.找到解压路径的conf ...