这游戏前一段时间传的很火,前几天早上实在太无聊了,就决定把这游戏自己也写一个。
前后写了一个多小时吧,大概300行左右,没什么复杂算法,不过实在懒得去优化了,但估计优化完能控制在200行以下,有兴趣的朋友可以自己优化一下。
说明:我一开始玩的是IOS APP版的TRHEES,后来才玩的2048,两者在滑动的规则上有些区别,本人这个版本是这两者的结合。
最后,祝试玩愉快!
界面丑陋,求不笑。
以下是源代码:
int panemax() //棋盘最大数
{
int max=pane[0][0];
for(int i=0;i<=3;i++)
for(int j=0;j<=3;j++)
if(pane[i][j]>max)
max=pane[i][j];
return max;
}
int ifwin() //判断是否胜利
{
int flag=0;
if(panemax()==2048)
{
cout<<setw(45)<<"You Win!"<<endl;
flag=1;
}
return flag;
}
int ifGameOver() //判断是否游戏结束
{
int flag=0;
if(testup()+ testdown() + testleft() + testright() == 0)
{
cout<<setw(43)<<"Game Over!"<<endl;
flag=1;
}
return flag;
}
void addnewnumberup() //上移后添加新数
{
srand( (unsigned)time( NULL ) );
int n;
if(N==1)
n=1;
else
n=(rand()%(N)+1);
int newnumber=pow(2,n);
for(int i=3;i>=0;i--)
for(int j=0;j<=3;j++)
if(pane[i][j]==0)
{
pane[i][j]=newnumber;
return;
}
}
void addnewnumberdown() //下移后添加新数
{
srand( (unsigned)time( NULL ) );
int n;
if(N==1)
n=1;
else
n=(rand()%(N)+1);
int newnumber=pow(2,n);
for(int i=0;i<=3;i++)
for(int j=0;j<=3;j++)
if(pane[i][j]==0)
{
pane[i][j]=newnumber;
return;
}
}
void addnewnumberleft() //左移后添加新数
{
srand( (unsigned)time( NULL ) );
int n;
if(N==1)
n=1;
else
n=(rand()%(N)+1);
int newnumber=pow(2,n);
f