#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. python接口自动化(九)--python中字典和json的区别(详解)

    简介 这篇文章的由来是由于上一篇发送post请求的接口时候,参数传字典(dict)和json的缘故,因为python中,json和dict非常类似,都是key-value的形式,为啥还要这么传参,在群 ...

  2. CanalSharp-mysql数据库binlog的增量订阅&消费组件Canal的.NET客户端

    一.前言 CanalSharp是阿里巴巴开源项目mysql数据库binlog的增量订阅&消费组件 Canal 的.NET客户端,关于什么是 Canal?又能做什么?我会在后文为大家一一介绍.C ...

  3. Accept 与 Content-Type

    Accept 表示请求方希望的资源类型,或者能解析识别的类型 Content-Type 表示实际发送的资源类型 这里资源类型通过 MIME types 表示. Accept Accept 是浏览器发送 ...

  4. Python:logging.NullHandler 的使用

    在使用 peewee 框架时,默认是不会出现日志消息的. from peewee import Model, CharField, DateTimeField, IntegerField from p ...

  5. 极光推送经验之谈-Java后台服务器实现极光推送的两种实现方式

    原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/6439313.html Java后台实现极光推送有两种方式,一种是使用极光推送官方提供的推送请 ...

  6. ado.net的简单数据库操作(二)之封装SqlHelperl类

    今天我书接上回,接着昨天的ado.net的数据库操作的相关知识来讲哈! 从上篇文章给出的实例来看,你一定会发现,操作数据库其实还挺麻烦的,就连一个最简单的数据库操作语句都要包括 定义数据库连接字符串. ...

  7. 从零开始学安全(四十二)●利用Wireshark分析ARP协议数据包

    wireshark:是一个网络封包分析软件.网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料.Wireshark使用WinPCAP作为接口,直接与网卡进行数据报文交换,是目前 ...

  8. ASP.NET应用程序服务器集群方案

    本文采用Nginx来实现ASP.NET程序集群化. 准备环境 首先准备Nginx环境,Windows版本下载链接:http://nginx.org/en/download.html 解压后文件格式如下 ...

  9. c#封装DBHelper类

    public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> None, /// <s ...

  10. wkhtmltox实现网页转换成图片或pdf

    1.先下载http://download.gna.org/wkhtmltopdf/obsolete/windows/wkhtmltox-0.11.0_rc1-installer.exe,安装 2.在命 ...