概述
控制台版2048比较好实现,就用它来做.
下面是 game.h文件
// 山寨黑框框 2048
#include
#include
#include
using namespace std;
#define rand(x) ( rand() % (x) )
#define UP
1
#define DOWN
2
#define LEFT
3
#define RIGHT 4
struct POS
{
int x;
int y;
};
class Game
{
public:
Game();
~Game();
int
get_random_2or4();
bool get_null_pos(POS &pos);
bool set_2or4_pos(int m,POS &pos);
bool merge(int direction,bool realMerge);
bool isGameOver();
bool set_userinput(char c);
bool has2048();
void printArray();
private:
int a[4][4];
};
Game::Game()
{
// 设置随机数种子
srand((unsigned(time(0))));
// 初始化数组
for(int i = 0; i < 4;i++)
for(int j = 0;j < 4;j++)
a[i][j] = 0;
for(int i = 0; i < 2;i++)
{
// 随机生成2或4
int m = get_random_2or4();
// 设置数字位置
POS pos;
get_null_pos(pos);
set_2or4_pos(m,pos);
}
printArray();
}
Game::~Game()
{
}
int Game::get_random_2or4()
{
int m = rand(4); // 返回0,1,2,3
// 返回2 和4 的比例为3 : 1
return m < 3 ? 2 : 4;
}
bool Game::get_null_pos(POS &pos)
{
POS available_pos[16];
int n = 0;
for(int i = 0;i < 4;i++)
for(int j = 0;j < 4;j++)
if(a[i][j] == 0)
{
available_pos[n].x = i;
available_pos[n].y = j;
n++;
}
// 没有空余位置
if(n == 0)
return false;
else
{
int rand_i = rand(n);
pos = available_pos[rand_i];
return true;
}
}
bool Game::set_2or4_pos(int m,POS &pos)
{
a[pos.x][pos.y] = m;
return true;
}
bool Game::merge(int direction,bool realMerge = false)
{
int nRet = false;
// 拷贝数组a到数组b
int b[4][4];
for(int i = 0;i < 4;i++)
for(int j = 0;j < 4;j++)
b[i][j] = a[i][j];
if(direction == UP)
{
// 向上合并
for(int i = 0;i < 4;i++)
{
int has_merge = false; // 对一行只合并一次
for(int j = 1;j < 4;j++)
{
// 若位置为空,跳过
if(b[j][i] == 0)
continue;
// 该位置非空
int former_index = j;
int current_index = j - 1;
int val = b[j][i];
// 向上替换掉空位置直到顶部或者遇到方块
while(current_index >= 0 && b[current_index][i] == 0)
{
b[current_index][i] = val;
b[former_index][i]
= 0;
former_index = current_index;
current_index -- ;
}
// 如果遇到的是相同方块
if(current_index >= 0 && b[current_index][i] == val)
{
if(!has_merge)
// 若该行未合并过,则合并
{
has_merge = true;
b[current_index][i] *= 2;
b[former_index][i]
= 0;
}
}
}
if(has_merge == true)
nRet = true;
}
}
if(direction == DOWN)
{
// 向上合并
for(int i = 0;i < 4;i++)
{
int has_merge = false; // 对一行只合并一次
for(int j = 2;j >= 0;j--)
{
// 若位置为空,跳过
if(b[j][i] == 0)
continue;
// 该位置非空
int former_index = j;
int current_index = j + 1 ;
int val = b[j][i];
// 向上替换掉空位置直到顶部或者遇到方块
while(current_index < 4 && b[current_index][i] == 0)
{
b[current_index][i] = val;
b[former_index][i]
= 0;
former_index = current_index;
current_index ++ ;
}
// 如果遇到的是相同方块
if(current_index < 4 && b[current_index][i] == val)
{
if(!has_merge)
// 若该行未合并过,则合并
{
has_merge = true;
b[current_index][i] *= 2;
b[former_index][i]
= 0;
}
}
}
if(has_merge == true)
nRet = true;
}
}
if(direction == LEFT)
{
// 向左合并
for(int i = 0; i < 4; i++)
{
int has_merge = false; // 对一行只合并一次
for(int j = 1;j < 4 ; j ++)
{
if(b[i][j] == 0)
continue;
int former_index = j;
int current_index = j - 1;
int val = b[i][j];
向上替换掉空位置直到顶部或者遇到方块
while(current_index >= 0 && b[i][current_index] == 0)
{
b[i][current_index] = val;
b[i][former_index]
= 0;
former_index = current_index;
current_index -- ;
}
// 如果遇到的是相同方块
if(current_index >= 0 && b[i][current_index] == val)
{
if(!has_merge)
// 若该行未合并过,则合并
{
has_merge = true;
b[i][current_index] *= 2;
b[i][former_index]
= 0;
}
}
}
if(has_merge == true)
nRet = true;
}
}
if(direction == RIGHT)
{
// 向右合并
for(int i = 0; i < 4; i++)
{
int has_merge = false; // 对一行只合并一次
for(int j = 2;j >= 0 ; j --)
{
if(b[i][j] == 0)
continue;
int former_index = j;
int current_index = j + 1;
int val = b[i][j];
向上替换掉空位置直到顶部或者遇到方块
while(current_index < 4 && b[i][current_index] == 0)
{
b[i][current_index] = val;
b[i][former_index]
= 0;
former_index = current_index;
current_index ++ ;
}
// 如果遇到的是相同方块
if(current_index < 4 && b[i][current_index] == val)
{
if(!has_merge)
// 若该行未合并过,则合并
{
has_merge = true;
b[i][current_index] *= 2;
b[i][former_index]
= 0;
}
}
}
if(has_merge == true)
nRet = true;
}
}
if(realMerge == true)
{
for(int i = 0;i < 4;i++)
for(int j = 0;j < 4;j++)
a[i][j] = b[i][j];
}
return nRet;
}
bool Game::isGameOver()
{
POS pos;
if(get_null_pos(pos) == false)
{
int nRet = false;
nRet |= merge(UP,false);
nRet |= merge(DOWN,false);
nRet |= merge(LEFT,false);
nRet |= merge(RIGHT,false);
if(nRet == false)
return true;
}
return false;
}
bool Game::set_userinput(char c)
{
int direction = 0;
switch (c)
{
case 'i':
direction = UP;break;
case 'k':
direction = DOWN;break;
case 'j':
direction = LEFT;break;
case 'l':
direction = RIGHT;break;
default:
return false;
}
// 合并
merge(direction,true);
int m = get_random_2or4();
POS pos;
if(get_null_pos(pos))
set_2or4_pos(m,pos);
printArray();
return true;
}
void Game::printArray()
{
static long turns = 1;
// -------------------------
//
|
|
|
|
|
//
-------------------------
//
|
|
|
|
|
//
-------------------------
//
|
|
|
|
|
//
-------------------------
//
|
|
|
|
|
//
-------------------------
cout << "这是第"<< left << setw(5) << turns++ << "轮"<< endl;
for(int i = 0;i < 25;i++)
cout << '-';
cout << endl;
for(int i = 0; i < 4;i++)
{
for(int j = 0;j < 4;j++)
{
cout << '|';
cout << ' ';
if(a[i][j] != 0)
cout << left << setw(4) << a[i][j];
else
cout << left << setw(4) << ' ';
}
cout << '|';
cout << endl;
for(int k = 0;k < 25;k++)
cout << '-';
cout << endl;
}
cout << endl;
}
bool Game::has2048()
{
for(int i = 0; i < 4 ;i++)
for(int j = 0; j < 4;j++)
if(a[i][j] == 2048)
return true;
return false;
}
下面是 main.cpp文件
#include "game.h"
#include
int main()
{
cout << "---------------------------------" <
最后
以上就是有魅力店员为你收集整理的C++ 实现 2048 (控制台版)的全部内容,希望文章能够帮你解决C++ 实现 2048 (控制台版)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复