#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控制台游戏的更多相关文章

  1. [c++项目]迷宫 控制台游戏

    #include<stdio.h> #include<windows.h> #include<stdlib.h> #include<time.h> #i ...

  2. c语言----<项目>_小游戏<2048>

    2048 小游戏 主要是针对逻辑思维的一个训练. 主要学习方面:1.随机数产生的概率.2.行与列在进行移动的时候几种情况.3.MessageBox的使用 #include <iostream&g ...

  3. c#撸的控制台版2048小游戏

    1.分析 最近心血来潮,突然想写一个2048小游戏.于是搜索了一个在线2048玩玩,熟悉熟悉规则. 只谈核心规则:(以左移为例) 1.1合并 以行为单位,忽略0位,每列依次向左进行合并,且每列只能合并 ...

  4. Swift实战之2048小游戏

    上周在图书馆借了一本Swift语言实战入门,入个门玩一玩^_^正好这本书的后面有一个2048小游戏的实例,笔者跟着实战了一把. 差不多一周的时间,到今天,游戏的基本功能已基本实现,细节我已不打算继续完 ...

  5. 【2048小游戏】——CSS/原生js爬坑之纯CSS模态对话框&游戏结束

    引言:2048小游戏的结束界面,使用纯CSS制作模态对话框,一般做模态对话框都会使用BootStrap自带的模态对话框组件方便使用,但在制作要运行在移动端的小项目时,就不能使用BootStrap,因为 ...

  6. .NET手撸2048小游戏

    .NET手撸2048小游戏 2048是一款益智小游戏,得益于其规则简单,又和2的倍数有关,因此广为人知,特别是广受程序员的喜爱. 本文将再次使用我自制的"准游戏引擎"FlysEng ...

  7. jQuery实践-网页版2048小游戏

    ▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...

  8. 控制台游戏引擎CGE——贪吃蛇

    今天我也来发一个控制台游戏.先看图: 缘起 LZ是一个有严重拖延症的人,表现的形式就是隔一段时间就要刷一刷博客园. 这不前几天,看到了魏大师<使用Lua脚本语言开发出高扩展性的系统...> ...

  9. C# 开发2048小游戏

    这应该是几个月前,闲的手痒,敲了一上午代码搞出来的,随之就把它丢弃了,当时让别人玩过,提过几条更改建议,但是时至今日,我也没有进行过优化和更改(本人只会作案,不会收场,嘎嘎),下面的建议要给代码爱好的 ...

随机推荐

  1. 详解IPTABLES

    详解IPTABLES Iptables 是Linux 内核集成的 IP 信息包过滤系统.如果Linux 系统连接到因特网或 LAN.服务器或连接 LAN 和因特网的代理服务器, 则该系统有利于在 Li ...

  2. 【Android Studio安装部署系列】十八、Android studio更换APP应用图标

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 Android Studio新建项目后会有一个默认图标,那么如何更换图标呢? 替换图标 这个方案不建议直接在已有项目上更换图标,建议 ...

  3. 『集群』001 Slithice 服务器集群 概述

    Slithice 服务器集群 概述 Slithice是做什么的 Slithice 是一个 跨平台 的 分布式架构 框架: 旨在简化 分布式开发 的开发难度,节省 开发成本 和 后期维护成本: 并提供 ...

  4. Asp.Net Core 轻松学-HttpClient的演进和避坑

    前言     在 Asp.Net Core 1.0 时代,由于设计上的问题, HttpClient 给开发者带来了无尽的困扰,用 Asp.Net Core 开发团队的话来说就是:我们注意到,HttpC ...

  5. 四种途径提高RabbitMQ传输消息数据的可靠性(一)

    前言 RabbitMQ虽然有对队列及消息等的一些持久化设置,但其实光光只是这一个是不能够保障数据的可靠性的,下面我们提出这样的质疑: (1)RabbitMQ生产者是不知道自己发布的消息是否已经正确达到 ...

  6. 关于Exceptionless的使用注意

    大家都应该比较熟悉NLOG,我们知道log4net和nlog,也有其它的记日志框架.目前我们的生产环境使用nlog,而且对Exceptionless的对接也是无缝的.可能有人会问为什么不用ELK,主要 ...

  7. 使用C# 操作存储过程,执行sql语句通用类

    如何使用C# 操作存储过程,执行sql语句? 闲话不多说,直接上代码:     /// <summary>    /// Sql通用类    /// </summary>    ...

  8. shiro缓存管理

    一. 概述 Shiro作为一个开源的权限框架,其组件化的设计思想使得开发者可以根据具体业务场景灵活地实现权限管理方案,权限粒度的控制非常方便.首先,我们来看看Shiro框架的架构图:从上图我们可以很清 ...

  9. js无法获取.net设置的cookie

    使用CookieHelper帮助类: public class CookieHelper { #region 获取Cookie /// <summary> /// 获得Cookie的值 / ...

  10. webpack4.x笔记-配置基本的前端开发环境(一)

    webpack的基本使用 webpack 本质上是一个打包工具,它会根据代码的内容解析模块依赖,帮助我们把多个模块的代码打包.借用 webpack 官网的图片: 虽然webpack4.x的版本可以零配 ...