代码如下:

 #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. 浅析TCP三次握手及四次挥手

    1. 三次握手 1. TCP为什么相较于UDP是可靠连接? 可靠连接是指,待通信的两个实体,能够满足通信数据包的有序性.完整性以及可靠性.对于UDP来说, 它的连接过程不需要握手,忽略丢失的数据包,并 ...

  2. 初识kubernetes

    Kubernetes最初源于谷歌内部的Borg,提供了面向应用的容器集群部署和管理系统.Kubernetes 的目标旨在消除编排物理/虚拟计算,网络和存储基础设施的负担,并使应用程序运营商和开发人员完 ...

  3. css设置使文字显示2行多余的为省略号...

    1 2 3 4 5 6 7 8 9 10 11 12 .title{        font-size: .7rem;        line-height: 1.5rem;          ove ...

  4. MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是"插入了enum的第一个值"?

    刚刚在看<<深入浅出MySQL>>一书的"ENUM类型"一节, 以下面的代码举例, 得出结论: "还可以看出对于不在ENUM指定范围内的值时, 并 ...

  5. 信息论 | information theory | 信息度量 | information measures | R代码(一)

    这个时代已经是多学科相互渗透的时代,纯粹的传统学科在没落,新兴的交叉学科在不断兴起. life science neurosciences statistics computer science in ...

  6. Idea2019.2破解

    1.在 hosts 文件里加入如下的配置:C:\WINDOWS\system32\drivers\etc\hosts 0.0.0.0 https://account.jetbrains.com:443 ...

  7. 扩展和嵌入 Python 解释器 用 C 或 C++ 编写模块以使用新模块来扩展 Python 解释器的功能 定义新的函数\对象类型\方法。 将 Python 解释器嵌入到另一个应用程序中

    // https://python3-cookbook.readthedocs.io/zh_CN/latest/c15/p02_write_simple_c_extension_module.html ...

  8. javaweb--Rest访问(RestTemplate)

    Rest访问(RestTemplate)在实际的项目中,往往需要发送一个Get/Post请求到其他的系统(Rest API),比如向人员管理部门请求,然后解析返回信息获取该用户的基本信息等.JDK传统 ...

  9. nginx: [warn] conflicting server name "aaa.bbbb.com" on 0.0.0.0:80, ignored

    date: 2019-08-12  16:52:44 author: headsen chen notice :个人原创 故障现象: openresty -t nginx: [warn] confli ...

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

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