代码如下:

 #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. mysql集群高可用架构

    前言 高可用架构对于互联网服务基本是标配,无论是应用服务还是数据库服务都需要做到高可用.对于一个系统而言,可能包含很多模块,比如前端应用,缓存,数据库,搜索,消息队列等,每个模块都需要做到高可用,才能 ...

  2. 已知 sqrt (2)约等于 1.414,要求不用数学库,求 sqrt (2)精确到小数点后 10 位

    问题:已知 sqrt (2)约等于 1.414,要求不用数学库,求 sqrt (2)精确到小数点后 10 位. 出题人:阿里巴巴出题专家:文景/阿里云 CDN 资深技术专家. 考察点:基础算法的灵活应 ...

  3. markdown 插入链接

    插入链接 []里面写链接的标题或描述,可以省略不加不写 , () 里面是链接,必须有必须写 例如 [百度](https://www.baidu.com) 百度 参考文章 Markdown 插入链接

  4. 利用Git上传项目到github以及遇到的问题

    今天学习如何利用git从本地端上传项目,以及遇到问题的解决方法 1.要有自己的github账号,并创建一个仓库, 2.输入仓库的名称,直接Create 注:记住常见成功后的这个地址,后边要用到: 3. ...

  5. python 画园和椭圆

    from matplotlib.patches import Ellipse, Circle import matplotlib.pyplot as plt fig = plt.figure() ax ...

  6. OSG学习笔记0——解决OSG读obj模型问题[转]

    原文:https://blog.csdn.net/u011310341/article/details/51179948 #include "stdafx.h" #include& ...

  7. Spark(四十八):Spark MetricsSystem信息收集过程分析

    MetricsSystem信息收集过程 参考: <Apache Spark源码走读之21 -- WEB UI和Metrics初始化及数据更新过程分析> <Spark Metrics配 ...

  8. git 代码版本回退

    1.查看 commit id 2.git reset --hard "dfdfdfdf" // commit id 3.git push -f -u origin 2.1.0 // ...

  9. IntelliJ Idea设置默认换行符 Idea

    http://hbyepei.github.io/2016/03/13/设置默认换行符/

  10. crontab 使用日期时间命名重定向文件

    使用月份命名 0 12 * * * sh /tmp/test.sh >> "/tmp/$(date +"\%Y-\%m").log" 2>&a ...