[C++项目]2048控制台游戏
#include <iostream>
#include <windows.h>
#include <ctime>
using namespace std; int const ROW = ;
int const COL = ;
int game[ROW][COL] = {}; //上下左右
int const UP = ;
int const DOWN = ;
int const LEFT = ;
int const RIGHT = ; //游戏所处的状态
int const GAME_OVER = ;
int const GAME_WIN = ;
int const GAME_CONTINUE = ; enum GameNum
{
Game_2 = ,
Game_4 = ,
Game_8 = ,
Game_16 = ,
Game_32 = ,
Game_64 = ,
Game_128 = ,
Game_256 = ,
Game_512 = ,
Game_1024 = ,
Game_2048 = ,
}; //打印所得的数组
void Print()
{
system("cls");
cout << "***************** 2048 控 制 台 版 ******************" << endl;
cout << "***************** By Linxu ******************" << endl << endl;
for (int i = ; i < ROW; ++i)
{
cout << "================================"<< endl;
for (int j = ; j < COL; ++j)
{
if (game[i][j] == )
{
cout <<"| \t";
}
else
{
cout <<"| " << game[i][j] << "\t";
}
}
cout << "|" << endl;
}
cout << "================================"<< endl;
cout << "【操作说明】:"<< endl;
cout << "请使用按照↑↓←→控制移动方向" << endl << endl;
} bool CreateNumber()
{
int x = -;
int y = -;
int times = ;
int maxTimes = ROW * COL;
//三分之二的概率生成2,三分之一的概率生成4
int whitch = rand() % ;
do
{
x = rand() % ROW;
y = rand() % COL;
++times;
} while (game[x][y] != && times <= maxTimes); //说明格子已经满了
if(times >= maxTimes)
{
return false;
}
else
{
GameNum num;
if(whitch == )
{
num = Game_4;
}
else if(whitch)
{
num = Game_2;
}
game[x][y] = num;
} return true;
} void Process(int direction)
{
switch (direction)
{
case UP:
//最上面一行不动
for(int row = ; row < ROW; ++row)
{
for(int crow = row; crow >= ; --crow)
{
for(int col = ; col < COL; ++col)
{
//上一个格子为空
if(game[crow-][col] == )
{
game[crow-][col] = game[crow][col];
game[crow][col] = ;
}
else
{
//合并
if(game[crow-][col] == game[crow][col])
{
game[crow - ][col] *= ;
game[crow][col] = ;
} }
}
}
}
break;
case DOWN:
//最下面一行不动
for(int row = ROW - ; row >= ; --row)
{
for(int crow = row; crow < ROW - ; ++crow)
{
for(int col = ; col < COL; ++col)
{
//上一个格子为空
if(game[crow + ][col] == )
{
game[crow + ][col] = game[crow][col];
game[crow][col] = ;
}
else
{
//合并
if(game[crow + ][col] == game[crow][col])
{
game[crow + ][col] *= ;
game[crow][col] = ;
} }
}
}
}
break;
case LEFT:
//最左边一列不动
for(int col = ; col < COL; ++col)
{
for(int ccol = col; ccol >= ; --ccol)
{
for(int row = ; row < ROW; ++row)
{
//上一个格子为空
if(game[row][ccol-] == )
{
game[row][ccol - ] = game[row][ccol];
game[row][ccol] = ;
}
else
{
//合并
if(game[row][ccol - ] == game[row][ccol])
{
game[row][ccol - ] *= ;
game[row][ccol] = ;
} }
}
}
}
break;
case RIGHT:
//最右边一列不动
for(int col = COL - ; col >= ; --col)
{
for(int ccol = col; ccol <= COL - ; ++ccol)
{
for(int row = ; row < ROW; ++row)
{
//上一个格子为空
if(game[row][ccol + ] == )
{
game[row][ccol + ] = game[row][ccol];
game[row][ccol] = ;
}
else
{
//合并
if(game[row][ccol + ] == game[row][ccol])
{
game[row][ccol + ] *= ;
game[row][ccol] = ;
} }
}
}
}
break;
} } //处理输入输出,返回上下左右
int Input()
{
//读取上下左右四个方向键
int upArrow = ;
int downArrow = ;
int leftArrow = ;
int rightArrow = ;
int direction = ;
while (true)
{
upArrow = GetAsyncKeyState(VK_UP);
downArrow = GetAsyncKeyState(VK_DOWN);
leftArrow = GetAsyncKeyState(VK_LEFT);
rightArrow = GetAsyncKeyState(VK_RIGHT); if(upArrow)
{
direction = UP;
break;
}
else if(downArrow)
{
direction = DOWN;
break;
}
else if(leftArrow)
{
direction = LEFT;
break;
}
else if(rightArrow)
{
direction = RIGHT;
break;
} Sleep();
} return direction;
} //判断游戏状态
int Judge()
{
//赢得游戏
for(int i = ; i < ROW; ++i)
{
for(int j = ; j < COL; ++j)
{
if(game[i][j] == )
{
return GAME_WIN;
break;
}
}
} //横向检查
for(int i = ; i < ROW; ++i)
{
for(int j = ; j < COL - ; ++j)
{
if(!game[i][j] || (game[i][j] == game[i][j+]))
{
return GAME_CONTINUE;
break;
}
}
}
//纵向检查
for(int j = ; j< COL; ++j)
{
for(int i = ; i < ROW -; ++i)
{
if(!game[i][j] || (game[i][j] == game[i+][j]))
{
return GAME_CONTINUE;
break;
}
}
} //不符合上述两种状况,游戏结束
return GAME_OVER; } int main()
{
//设置一个随机数种子
srand((unsigned int)time());
CreateNumber();
CreateNumber();
Print();
int direction = ;
int gameState = -;
while(true)
{
direction = Input(); gameState = Judge();
if(direction && gameState == GAME_CONTINUE)
{
Process(direction);
CreateNumber();
Print();
Sleep();
}
else if(gameState == GAME_WIN)
{
Print();
cout << "You Win!" << endl;
break;
}
else if(gameState == GAME_OVER)
{
Print();
cout <<"You lose!" << endl;
break;
}
} return ;
}
[C++项目]2048控制台游戏的更多相关文章
- [c++项目]迷宫 控制台游戏
#include<stdio.h> #include<windows.h> #include<stdlib.h> #include<time.h> #i ...
- c语言----<项目>_小游戏<2048>
2048 小游戏 主要是针对逻辑思维的一个训练. 主要学习方面:1.随机数产生的概率.2.行与列在进行移动的时候几种情况.3.MessageBox的使用 #include <iostream&g ...
- c#撸的控制台版2048小游戏
1.分析 最近心血来潮,突然想写一个2048小游戏.于是搜索了一个在线2048玩玩,熟悉熟悉规则. 只谈核心规则:(以左移为例) 1.1合并 以行为单位,忽略0位,每列依次向左进行合并,且每列只能合并 ...
- Swift实战之2048小游戏
上周在图书馆借了一本Swift语言实战入门,入个门玩一玩^_^正好这本书的后面有一个2048小游戏的实例,笔者跟着实战了一把. 差不多一周的时间,到今天,游戏的基本功能已基本实现,细节我已不打算继续完 ...
- 【2048小游戏】——CSS/原生js爬坑之纯CSS模态对话框&游戏结束
引言:2048小游戏的结束界面,使用纯CSS制作模态对话框,一般做模态对话框都会使用BootStrap自带的模态对话框组件方便使用,但在制作要运行在移动端的小项目时,就不能使用BootStrap,因为 ...
- .NET手撸2048小游戏
.NET手撸2048小游戏 2048是一款益智小游戏,得益于其规则简单,又和2的倍数有关,因此广为人知,特别是广受程序员的喜爱. 本文将再次使用我自制的"准游戏引擎"FlysEng ...
- jQuery实践-网页版2048小游戏
▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...
- 控制台游戏引擎CGE——贪吃蛇
今天我也来发一个控制台游戏.先看图: 缘起 LZ是一个有严重拖延症的人,表现的形式就是隔一段时间就要刷一刷博客园. 这不前几天,看到了魏大师<使用Lua脚本语言开发出高扩展性的系统...> ...
- C# 开发2048小游戏
这应该是几个月前,闲的手痒,敲了一上午代码搞出来的,随之就把它丢弃了,当时让别人玩过,提过几条更改建议,但是时至今日,我也没有进行过优化和更改(本人只会作案,不会收场,嘎嘎),下面的建议要给代码爱好的 ...
随机推荐
- .NET Core微服务之基于Steeltoe使用Hystrix熔断保护与监控
Tip: 此篇已加入.NET Core微服务基础系列文章索引 => Steeltoe目录快速导航: 1. 基于Steeltoe使用Spring Cloud Eureka 2. 基于Steelt ...
- TypeScript 中非代码模块的导入
需要理解的是,TypeScript 作为语言,他只处理代码模块.其他类型的文件这种非代码模块的导入,讲道理是通过另外的打包工具来完成的,比如 Web 应用中的图片,样式,JSON 还有 HTML 模板 ...
- SpringBoot是怎么在实例化时候将bean加载进入容器中
之前写过的很多spring文章,都是基于应用方面的,这次的话,就带大家来一次对spring的源码追踪,看一看spring到底是怎么进行的初始化,如何创建的bean,相信很多刚刚接触spring的朋友, ...
- Reactor 典型的 NIO 编程模型
Doug Lea 在 Scalable IO in Java 的 PPT 中描述了 Reactor 编程模型的思想,大部分 NIO 框架和一些中间件的 NIO 编程都与它一样或是它的变体.本文结合 P ...
- 【大数据安全】CDH集群禁用Kerberos
在调试Kerberos的时候可能会有需要禁用的场景.以下是各组件禁用Kerberos的相关配置. 环境 CDH版本:5.11.2 Linux版本:7.4.1708 Docker版本:Docker ve ...
- python3-列表字典简单练习题
.求全部元素的和[,,,,,,,] >>> a=[,,,,,,,] >>> result= >>> for i in a: ... result+ ...
- python -使用del语句删除对象引用
使用del语句删除一些对象引用. 注意不是把内存地址删了,你只是删除了引用,它就变为了一个可回收的对象,内存会不定期回收. del语句的语法是: del var1[,var2[,var3[....,v ...
- List去重的实现
List<T> 当T为值类型的时候 去重比较简单,当T为引用类型时,一般根据业务需要,根据T的中几个属性来确定是否重复,从而去重. 查看System.Linq下的Enumerable存在一 ...
- 并发concurrent---3
背景:并发知识是一个程序员段位升级的体现,同样也是进入BAT的必经之路,有必要把并发知识重新梳理一遍. ConcurrentHashMap:在有了并发的基础知识以后,再来研究concurrent包.普 ...
- Linux系统上安装MySQL(rpm)
1.准备工作 从MySQL官网上分别下载mysql服务器端于客户端包. 如: MySQL-server-5.5.15-1.linux2.6.x86_64.rpm和MySQL-client-5.5.15 ...