代码如下:

 #define _CRT_SECURE_NO_WARNINGS//去掉编译器内部扩增问题
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<graphics.h>//需要下载图形库
#include<conio.h>
#include<time.h>
#include<string>
#include<fstream>
#include<iostream>
#include<sstream>
using namespace std; namespace
{
IMAGE image[];
int imageIndex[];
int map[][] = { };
bool isOver = true;
bool gameOver = false;
enum direction
{
Up, Down, Left, Right
};
}; void SetImageIndex();//设置图片编号
void loadResource();
void drawMap();
void randIntNum();
void keyDownAndDraw();
bool TurnLeft(int s[][]);
void ChangeOnKeyDown(direction Direction); int main()
{
SetImageIndex();
loadResource();
initgraph(*,*+);//游戏界面大小
drawMap();
keyDownAndDraw();
system("pause");//防止闪屏
//closegraph();
//system("pause");
return ;
}
void SetImageIndex()
{
imageIndex[] = ;
for (int i = ; i < ; i++)
{
imageIndex[i] = int(pow(, i));
}
}
void loadResource()//加载图片
{
for (int i = ; i < ; i++)
{
char fileName[] = "";
sprintf(fileName, "%d.bmp", imageIndex[i]);//拼接
loadimage(image + i, fileName,,);
}
} //画地图
void drawMap()
{
string out;
int HistryHighlyScore = ;
ifstream IScore("Score.txt");//创建文件读取历史最高分
if (!IScore)
{
ofstream OScore("Score.txt");
IScore.open("Score.txt");
}
getline(IScore, out);
char Score[];
char HighlyScore[];
int Sum=;
setbkcolor(RGB(, , ));
cleardevice();
settextcolor(WHITE);//设置文字颜色
settextstyle(, , "楷体");//设置文字格式
outtextxy(, , "2048游戏");
settextcolor(YELLOW);//设置文字颜色
settextstyle(, , "楷体");//设置文字格式
for (int i = ; i < ; i++)//计算分数
{
for (int j = ; j < ; j++)
{
if (map[i][j]>)
{
Sum += map[i][j] * sqrt(map[i][j]);
}
}
}
sprintf(Score, "分数:%d", Sum);
outtextxy(, ,Score);
for (int i = ; i < out.length(); i++)
{
HighlyScore[i] = out[i];
}
stringstream mid;
mid << out;
mid >> HistryHighlyScore;
if (HistryHighlyScore>Sum)
{
HighlyScore[out.length()] = '\0';
settextcolor(RED);//设置文字颜色
settextstyle(, , "楷体");//设置文字格式
outtextxy(, , "历史最高:");
outtextxy(, , HighlyScore);
}
else
{
char Score1[];
settextcolor(RED);//设置文字颜色
settextstyle(, , "楷体");//设置文字格式
sprintf(Score1, "历史最高:%d", Sum);
outtextxy(, ,Score1);
ofstream OScore1;
OScore1.open("Score.txt");
OScore1<<Sum;
OScore1.close();
}
IScore.close();
//根据二维数组去画图
int x, y, k;
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
x = * j;
y = * i + ;
for ( k = ; k < ; k++)
{
if (imageIndex[k] == map[i][j])
{
break;
}
}
putimage(x,y,image+k);
}
}
isOver = true;
} //随机产生2或者4;
void randIntNum()
{
bool haszero = false;
bool isOk=false;
srand((unsigned)time(NULL)); //随机函数种子
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
if (map[i][j] == )
{
haszero = true;
map[i][j] = (rand() % ) * ;
if (map[i][j] == )
{
continue;
}
isOk = true;
break;
}
}
if (isOk)
{
break;
}
}
if (!isOk)
{
isOk = false;
if (haszero)
{
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
if (map[i][j] == )
{
map[i][j] = ;
isOk = true;
break;
}
}
if (isOk)
{
break;
}
}
}
}
for (int i = ; i < ; i++)//检测最后一步是否留有空位,若全满游戏结束
{
for (int j = ; j < ; j++)
{
if (map[i][j] == )
{
drawMap();
return;
}
}
}
for (int i = ; i < ; i++)//游戏失败则重置
{
for (int j = ; j < ; j++)
{
if (i==&&j==)
{
map[i][j] = ;
continue;
}
map[i][j] = ;
}
}
drawMap();
} //按键响应
void keyDownAndDraw()
{
while (true)
{
char key = _getch();//接收用户按键
if (isOver)
{
isOver = false;
switch (key)
{
case 'W':
case'w':
case :
ChangeOnKeyDown(Up);
break;
case 'S':
case's':
case :
ChangeOnKeyDown(Down);
break;
case 'a':
case'A':
case :
ChangeOnKeyDown(Left);
break;
case 'D':
case'd':
case :
ChangeOnKeyDown(Right);
break;
default:
isOver = true;
break;
}
}
}
}
void ChangeOnKeyDown(direction Direction)
{
int Map[][] = { };
bool CanMove;
switch (Direction)//将所有方向改为向左方向,并利用向左算法计算各个方向
{
case Up:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
Map[j][i] = map[i][j];
}
}
break;
case Down:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
Map[j][-i] = map[i][j];
}
}
break;
case Left:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
Map[i][j] = map[i][j];
}
}
break;
case Right:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
Map[i][-j] = map[i][j];
}
}
break;
default:
break;
}
//向左算法
CanMove=TurnLeft(Map);
//将向左改回各自方向
switch (Direction)
{
case Up:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
map[j][i] =Map[i][j];
}
}
break;
case Down:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
map[-j][i] = Map[i][j];
}
}
break;
case Left:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
map[i][j] = Map[i][j];
}
}
break;
case Right:
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
map[i][-j] = Map[i][j];
}
}
break;
default:
break;
}
if (CanMove)
{
randIntNum();
drawMap();
}
else
{
isOver = true;
}
};
//算法
bool TurnLeft(int Map[][])//按向左键进行合并
{
int k;
int len;
int Save[];
int Move[][];
bool CanMove = false; for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
Move[i][j] = Map[i][j];
}
}
for (int i = ; i < ; i++)
{
k = ;
len = ;
for (int j = ; j < ; j++)
{
if (Map[i][j]==)
{
continue;
}
for (k = j+; k < ; k++)
{
if (Map[i][k] != )
{
if (Map[i][j] == Map[i][k])
{
Map[i][j] *= ;
Map[i][k] = ;
}
break;
}
}
}
for (int j = ; j < ; j++)
{
if (Map[i][j]!=)
{
Save[len]=Map[i][j];
len++;
}
}
for (int j = ; j < ; j++)
{
if (j<len)
{
Map[i][j] = Save[j];
}
else
{
Map[i][j] = ;
}
}
}
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
if (Move[i][j] != Map[i][j])
{
CanMove = true;
};
}
}
return CanMove;
}

图形库地址:

https://easyx.cn/downloads/

C++实现2048小游戏的更多相关文章

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

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

  2. C# 开发2048小游戏

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

  3. Swift实战之2048小游戏

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

  4. 如何在CentOS上安装一个2048小游戏

    如何在centos上安装一个2048小游戏 最近在学习CentOS系统,就琢磨着玩点什么,然后我看到有人在玩2048小游戏,所有我就在想,为啥不装一个2048小游戏搞一下嘞,于是乎,我就开始工作啦 由 ...

  5. js、jQuery实现2048小游戏

    2048小游戏 一.游戏简介:  2048是一款休闲益智类的数字叠加小游戏 二. 游戏玩法: 在4*4的16宫格中,您可以选择上.下.左.右四个方向进行操作,数字会按方向移动,相邻的两个数字相同就会合 ...

  6. 用js实现2048小游戏

    用js实现2048小游戏 笔记仓库:https://github.com/nnngu/LearningNotes 1.游戏简介 2048是一款休闲益智类的数字叠加小游戏.(文末给出源代码和演示地址) ...

  7. 2048小游戏代码解析 C语言版

    2048小游戏,也算是风靡一时的益智游戏.其背后实现的逻辑比较简单,代码量不算多,而且趣味性强,适合作为有语言基础的童鞋来加强编程训练.本篇分析2048小游戏的C语言实现代码. 前言 游戏截图:  游 ...

  8. Docker从0开始之部署一套2048小游戏

    本文记录一下在docker部署一套2048小游戏的过程,在娱乐中熟悉docker的应用部署.docker 安装不在本文讲述之中,参考我的其它博客. 1.获取image镜像. 方法一:daocloud. ...

  9. 使用JS实现2048小游戏

    JS实现2048小游戏源码 效果图: 代码如下,复制即可使用: (适用浏览器:360.FireFox.Chrome.Opera.傲游.搜狗.世界之窗. 不支持Safari.IE8及以下浏览器.) &l ...

  10. 2048小游戏4X4C语言

    */ #include<stdio.h> #include<stdlib.h> #include<conio.h> #include<time.h> v ...

随机推荐

  1. javascript中对一个对象数组按照对象某个属性进行排序

    需求:对timelist排序 安装keys . 分析:timelist 是个数组对象,里面包含属性 keys,val.这里借助数组sort方法 传入function <script> // ...

  2. macbook ios recovery and mount hfs+ journal and revert

    sudo fsck.hfsplus -fryd /dev/sdc2 /sbin/fsck_hfs -yprd /dev/partitionName---can not fix b-tree node ...

  3. html常用标签详解

    html常用标签详解 一.总结 一句话总结: 这些资料没必要自己总结,可以直接网上找,简单方便,再根据需求改一下 二.HTML常用标签详解 转自或参考:HTML常用标签详解https://blog.c ...

  4. Android系统分区

    Android系统开发时,经常会遇到添加或者调整系统分区大小的问题,下面以mstar的一款产品为例进行分析: (1)mount指令可以查看到板子中挂在的分区,主要关注ext4类型分区,例如tvserv ...

  5. Qt Resource System Qt资源体系(qrc rcc)

    Qt资源体系采用平台独立机制来存储应用程序执行时的二进制文件.这种机制在应用程序需要一些确定的文件(图标.翻译文件等等)而且又不想冒丢失文件的风险时是有用的. 资源体系依赖于 qmake, rcc ( ...

  6. button按钮的状态为disabled禁用状态,click事件无法触发,但是为什么touchstart下却依然可以触发

    切换到移动模拟模式,并点击按钮,查看控制台. 发现click没有事件没有触发,而touch事件依然触发. 解决办法: 对于移动端我们使用css来禁止按钮,达到disable的效果: 对,就是这个神奇的 ...

  7. 002 centos7中遇到的问题

    在关机的时候,发现输入密码之后竟然报错了,然后确认普通用户的密码没有问题.下面是处理方式. 一:问题 1.问题 当在终端执行sudo命令时,系统提示“caojun is not in the sudo ...

  8. 使用注解@Slf4j简化Logger的初始化

    一.是不是厌倦了 private final static Logger logger = LoggerFactory.getLogger(Application.class); 的拷贝和修改? 二. ...

  9. 在shell中判断hive查询记录数大小

     用途: 根据查询到结果数量来判断,是否需要再执行下个脚本. 1. 查询语句script.q脚本如下: ) as count from test; 2. shell脚本如下: 这里注意hive语句需要 ...

  10. Error-JavaScript:SCRIPT1007: 缺少 ']'

    ylbtech-Error-JavaScript:SCRIPT1007: 缺少 ']' SCRIPT1007: 缺少 ']' 1.返回顶部 · if (flag) { return eval(&quo ...