C++控制台应用程序之贪吃蛇(改进版)
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<conio.h>
#include<windows.h>
using namespace std; typedef struct{ int x, y; }Point; char map[][]; //定义一个22*22的地图(含边界)
Point snake[], food, Next; //定义蛇、食物、下一步蛇头的位置
int head, tail; //用于储存蛇头和蛇尾的下标
int grade, length, autotime; //游戏等级、蛇长、自动前进所需时间
char direction; //前进方向 //定位光标
void gotoxy(int x, int y)
{
HANDLE hConsoleOutput;
COORD dwCursorPosition;
dwCursorPosition.X = x;
dwCursorPosition.Y = y;
hConsoleOutput = GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleCursorPosition(hConsoleOutput, dwCursorPosition);
} //用inline定义内联函数节省程序运行时的调用开销
//刷新地图
inline void Update(char map[][], int grade, int length, int autotime)
{
//system("cls"); //清屏
gotoxy(, );
int i, j;
printf("\n");
for (i = ; i < ; i++)
{
printf("\t");
for (j = ; j < ; j++)
printf("%c ", map[i][j]);
if (i == )
printf("\t等级为:%d", grade);
if (i == )
printf("\t长度为:%d", length);
if (i == )
printf("\t自动前进时间");
if (i == )
printf("\t间隔为:%d ms", autotime);
printf("\n");
}
} //欢迎界面
inline void hello()
{
puts("\n\n\n\t\t\t贪吃蛇游戏即将开始!"); //准备开始
double start;
for (int i = ; i >= ; i--)
{
start = (double)clock() / CLOCKS_PER_SEC; //得到程序目前为止运行的时间
while ((double)clock() / CLOCKS_PER_SEC - start <= ); //经过1秒之后
if (i > )
{
system("cls"); //清屏
printf("\n\n\n\t\t\t进入倒计时:%d\n", i); //倒计时
}
else
Update(map, grade, length, autotime); //刷新地图
}
} //随机生成食物位置
inline void f()
{
srand(int(time())); //调用种子函数
do{
food.x = rand() % + ;
food.y = rand() % + ;
} while (map[food.x][food.y] != ' ');
map[food.x][food.y] = '!'; //食物为“!”
} //初始化
inline void init()
{
int i, j;
for (i = ; i <= ; i++)
for (j = ; j <= ; j++)
map[i][j] = ' ';
for (i = ; i <= ; i++)
map[][i] = map[][i] = map[i][] = map[i][] = '*'; //边界
map[][] = map[][] = 'O'; //蛇身(含蛇尾)
map[][] = '@'; //蛇头
head = ; tail = ; //开始时头和尾的下标
snake[head].x = ; snake[head].y = ; //开始时蛇头在地图上的下标
snake[tail].x = ; snake[tail].y = ; //开始时蛇尾在地图上的下标
snake[].x = ; snake[].y = ; //开始时蛇身在地图上的下标
f(); //随机生成食物位置
grade = ; length = ; autotime = ; //开始的等级、长度、自动前进时间
direction = ; //初始的运动方向向右
} //预前进
inline int GO()
{
bool timeover = true;
double start = (double)clock() / CLOCKS_PER_SEC; //得到程序目前为止运行的时间 L:
//自动经过1秒或者等待1秒内的键盘输入
while ((timeover = ((double)clock() / CLOCKS_PER_SEC - start <= autotime / 1000.0)) && !_kbhit());
//键盘输入
if (timeover)
{
//_getch();
char d = _getch(); //获取方向
if (d != && d != && d != && d != || direction == && d == || direction == && d == || direction == && d == || direction == && d == )
goto L;
else
direction = d;
}
switch (direction)
{
case :
Next.x = snake[head].x - ; Next.y = snake[head].y; //向上
break;
case :
Next.x = snake[head].x + ; Next.y = snake[head].y; //向下
break;
case :
Next.x = snake[head].x; Next.y = snake[head].y - ; //向左
break;
case :
Next.x = snake[head].x; Next.y = snake[head].y + ; //向右
break;
default:
puts("\tGame over!"); //按下非方向键游戏失败
return ;
}
if (Next.x == || Next.x == || Next.y == || Next.y == ) //撞到边界
{
puts("\tGame over!");
return ;
}
if (map[Next.x][Next.y] != ' '&&!(Next.x == food.x&&Next.y == food.y)) //吃到自己
{
puts("\tGame over!");
return ;
}
if (length == ) //最长蛇长
{
puts("\tGood game!");
return ;
}
return ;
} //吃到食物
inline void EAT()
{
length++; //长度增加1
int _grade = length / + ; //计算等级
if (_grade != grade)
{
grade = _grade;
if (autotime >= )
autotime = - grade * ; //增加一级自动时间减短50毫秒
}
map[Next.x][Next.y] = '@'; //蛇头位置变化
map[snake[head].x][snake[head].y] = 'O'; //原蛇头位置变化为蛇身
head = (head + ) % ; //蛇头下标加1
snake[head].x = Next.x; snake[head].y = Next.y; //蛇头下标变化
f(); //随机生成食物位置
Update(map, grade, length, autotime); //刷新地图
} //没吃到食物
inline void FAILURE()
{
map[snake[tail].x][snake[tail].y] = ' '; //蛇尾原来的位置变成“ ”
tail = (tail + ) % ; //蛇尾下标加1
map[Next.x][Next.y] = '@'; //蛇头位置变化
map[snake[head].x][snake[head].y] = 'O'; //原蛇头位置变化为蛇身
head = (head + ) % ; //蛇头下标加1
snake[head].x = Next.x; //蛇头下标变化
snake[head].y = Next.y;
Update(map, grade, length, autotime); //刷新地图
} //main函数
int main()
{
system("color F0");
init(); //初始化
hello(); //欢迎界面
while ()
{
if (GO()) //预前进
{
if (Next.x == food.x&&Next.y == food.y)
EAT(); //吃到食物
else
FAILURE(); //没吃到食物
}
else
return ; //失败或者胜利,游戏结束
}
return ;
}
//
运行结果截图:
C++控制台应用程序之贪吃蛇(改进版)的更多相关文章
- 控制台游戏引擎CGE——贪吃蛇
今天我也来发一个控制台游戏.先看图: 缘起 LZ是一个有严重拖延症的人,表现的形式就是隔一段时间就要刷一刷博客园. 这不前几天,看到了魏大师<使用Lua脚本语言开发出高扩展性的系统...> ...
- 贪吃蛇—C—基于easyx图形库(下):从画图程序到贪吃蛇【自带穿墙术】
上节我们用方向控制函数写了个小画图程序,它虽然简单好玩,但我们不应该止步于此.革命尚未成功,同志还需努力. 开始撸代码之前,我们先理清一下思路.和前面画图程序不同,贪吃蛇可以有很多节,可以用一个足够大 ...
- python【控制台】小游戏--贪吃蛇
传统贪吃蛇相信大家都玩过,也是一款很老很经典的游戏,今天我们用python控制台实现 项目有很多bug没有解决,因为本人一时兴起写的一个小游戏,所以只是实现可玩部分功能,并没有花较多的时间和精力去维护 ...
- WPF小程序:贪吃蛇
原文地址:http://hankjin.blog.163.com/blog/static/337319372009535108234/ 一共两个文件:EasterEgg.xaml + EasterEg ...
- C++之贪吃蛇
#include<iostream> #include<cstdio> #include<cstdlib> #include<ctime> #inclu ...
- 用C++实现的贪吃蛇游戏
我是一个C++初学者,控制台实现了一个贪吃蛇游戏. 代码如下: //"贪吃蛇游戏"V1.0 //李国良于2016年12月29日编写完成 #include <iostream& ...
- c/c++ 贪吃蛇控制台版
贪吃蛇控制台版(操作系统win7 64位:编译环境gcc, vs2017通过,其它环境未测试 不保证一定通过) 运行效果: #include <iomanip> #include < ...
- C++ 简单的控制台贪吃蛇小游戏
由于比较懒,所以不怎么写,觉得这样不应该.我应该对自己学的做出整理,不管是高端低端,写出来是自己的. // 贪吃蛇.cpp : 定义控制台应用程序的入口点. // #include "std ...
- C/C++编程笔记:C语言贪吃蛇源代码控制台(二),分数和食物!
接上文<C/C++编程笔记:C语言贪吃蛇源代码控制台(一),会动的那种哦!>如果你在学习C语言开发贪吃蛇的话,零基础建议从上一篇开始哦!接下来正式开始吧! 三.蛇的运动 上次我已经教大家画 ...
随机推荐
- python 的import机制2
http://blog.csdn.net/sirodeng/article/details/17095591 python 的import机制,以备忘: python中,每个py文件被称之为模块, ...
- JPA学习(2)注解
上一篇学习了JPA的helloworld,也初略的使用了一些注解,接下来就细细的了解一下有哪些注解,和这些注解的作用 JPA的基本注解: ①@Entity,@Table,@Id,@GeneratedV ...
- 整合spring,springmvc和mybatis
我创建的是maven项目,使用到的依赖架包有下面这些: <dependencies> <dependency> <groupId>org.springframewo ...
- [moka同学笔记]bootstrap基础
1.导航栏的制作 <nav class="nav navbar-default navbar-fixed-top" role="navigation"&g ...
- JSON的三种解析方式
一.什么是JSON? JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度. JSON就是一串字符串 只不过元素会使用特定 ...
- Java 上传文件到 SFTP 抛异常 java.lang.NoClassDefFoundError: Could not initialize class sun.security.ec.SunEC 的解决办法
最近从 Op 那里报来一个问题,说是SFTP上传文件不成功.拿到的 Exception 如下: Caused by: java.lang.NoClassDefFoundError: Could not ...
- [Architecture Design] 累进式Domain Layer
[Architecture Design] 累进式Domain Layer 前言 本篇的内容大幅度的简化了分析设计.面向对象等等相关知识,用以传达累进式Domain Layer的核心概念.实际开发软件 ...
- Javascript的一种代码结构方式——插件式
上几周一直在做公司的webos的前端代码的重构,之中对javascript的代码进行了重构(之前的代码耦合严重.拓展.修改起来比较困难),这里总结一下当中使用的一种代码结构——插件式(听起来怎么像独孤 ...
- 使用NPOI将多张图片导入execl
protected void btn_Export_Click(object sender, EventArgs e) { List<BNXX_SJXJ_XJSJ> list = View ...
- sublime text 3 安装
sublime text 3 下载地址 http://www.sublimetext.com/3 下载windows版本,然后解压缩就可以直接使用了,不错不错哦, 为了更加便捷的管理,安装 packa ...