码迷,mamicode.com
首页 > 编程语言 > 详细

热门游戏 2048 C++ 源代码分享

时间:2015-11-23 13:22:46      阅读:273      评论:0      收藏:0      [点我收藏+]

标签:

/*By Reason*/
#include<iostream>
#include <iomanip>
#include<math.h>
#include<stdlib.h>
#include<time.h>
#include <conio.h> //为了读取方向键
#include<windows.h>
using namespace std;
//srand( (unsigned)time( NULL ) ); //随机数种子 不能用在这里
int pane[4][4]; //棋盘
int N=1; //2的n次方
void showpane() //显示棋盘
{
 cout<<setw(46)<<"X2048 by Reason"<<endl;
 cout<<setw(50)<<" |-----------------------|"<<endl;
 for(int i=0;i<=3;i++)
 {
 cout<<setw(24)<<"";
 for(int j=0;j<=3;j++)
 {
 //SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_RED);
 cout<<setw(2)<<"|"<<setw(4)<<pane[i][j];

 if(j==3)
 {
 cout<<setw(2)<<"|"<<endl;
 cout<<setw(50)<<" |-----------------------|"<<endl;
 }
 }
 }
}
void newgame() //开始游戏
{
 N=1;
 for(int i=0;i<=3;i++) //初始化棋盘
 for(int j=0;j<=3;j++)
 pane[i][j]=0;
 srand( (unsigned)time( NULL ) );
 int m=rand()%4;
 int n=rand()%4;
 int p=rand()%4;
 int q=rand()%4;
 pane[m][n]=pane[p][q]=2;
 showpane();
}
int if2n(int x) //判断x是否是2的n次方
{
 int flag=0;
 for(int n=1;n<=11;n++)
 {
 if(x==pow(2,n))
 {
 flag=1;
 if(n>N)
 N=n;
 return flag;
 }
 }
 return flag;
}
int upmove() //上移
{
 int flag=0;
 for(int j=0;j<=3;j++)
 for(int i=0;i<3;i++)
 {
 if(if2n(pane[i][j]+pane[i+1][j])==1)
 {
 pane[i][j]=pane[i][j]+pane[i+1][j];
 pane[i+1][j]=0;
 flag=1;
 }
 }
 return flag;
}
int downmove() //下移
{
 int flag=0;
 for(int j=0;j<=3;j++)
 for(int i=3;i>0;i--)
 {
 if(if2n(pane[i][j]+pane[i-1][j])==1)
 {
 pane[i][j]=pane[i][j]+pane[i-1][j];
 pane[i-1][j]=0;
 flag=1;
 }
 }
 return flag;
}
int leftmove() //左移
{
 int flag=0;
 for(int i=0;i<=3;i++)
 for(int j=0;j<3;j++)
 {
 if(if2n(pane[i][j]+pane[i][j+1])==1)
 {
 pane[i][j]=pane[i][j]+pane[i][j+1];
 pane[i][j+1]=0;
 flag=1;
 }
 }
 return flag;
}
int rightmove() //右移
{
 int flag=0;
 for(int i=0;i<=3;i++)
 for(int j=3;j>0;j--)
 {
 if(if2n(pane[i][j]+pane[i][j-1])==1)
 {
 pane[i][j]=pane[i][j]+pane[i][j-1];
 pane[i][j-1]=0;
 flag=1;
 }
 }
 return flag;
}
int testup() //能否上移测试
{
 int flag=0;
 for(int j=0;j<=3;j++)
 for(int i=0;i<3;i++)
 {
 if(if2n(pane[i][j]+pane[i+1][j])==1)
 {
 flag=1;
 }
 }
 return flag;
}
int testdown() //测试能否下移
{
 int flag=0;
 for(int j=0;j<=3;j++)
 for(int i=3;i>0;i--)
 {
 if(if2n(pane[i][j]+pane[i-1][j])==1)
 {
 flag=1;
 }
 }
 return flag;
}
int testleft() //测试能否左移
{
 int flag=0;
 for(int i=0;i<=3;i++)
 for(int j=0;j<3;j++)
 {
 if(if2n(pane[i][j]+pane[i][j+1])==1)
 {
 flag=1;
 }
 }
 return flag;
}
int testright() //测试能否右移
{
 int flag=0;
 for(int i=0;i<=3;i++)
 for(int j=3;j>0;j--)
 {
 if(if2n(pane[i][j]+pane[i][j-1])==1)
 {
 flag=1;
 }
 }
 return flag;
}
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);
 for(int j=3;j>=0;j--)
 for(int i=0;i<=3;i++)
 if(pane[i][j]==0)
 {
 pane[i][j]=newnumber;
 return;
 }
}
void addnewnumberright() //右移后添加新数
{
 srand( (unsigned)time( NULL ) );
 int n;
 if(N==1)
 n=1;
 else
 n=(rand()%(N)+1);
 int newnumber=pow(2,n);
 for(int j=0;j<=3;j++)
 for(int i=0;i<=3;i++)
 if(pane[i][j]==0)
 {
 pane[i][j]=newnumber;
 return;
 }
}
int GetDirection() //读取方向
{
    int ret = 0;

    do
    {
        int ch = _getch();
        if(isascii(ch))
            continue;

        ch = _getch();
        switch(ch)
        {
        case 72:
            ret = 2; // top
            break;
        case 75:
            ret = 1; // left
            break;
        case 77:
            ret = 3; // right
            break;
        case 80:
            ret = 4; // down
            break;
        default:
            break;
        }
    } while (ret == 0);

    return ret;
}
int main() //主函数
{
 system("color f9");
 int makesure=1;
 while(makesure)
 {
 system("cls");
 newgame();
 while(ifwin()+ifGameOver()==0)
 {
 int c=GetDirection();
 switch(c)
 {
 case 2:
 upmove();
 addnewnumberup();
 system("cls");
 showpane();
 break;
 case 4:
 downmove();
 addnewnumberdown();
 system("cls");
 showpane();
 break;
 case 1:
 leftmove();
 addnewnumberleft();
 system("cls");
 showpane();
 break;
 case 3:
 rightmove();
 addnewnumberright();
 system("cls");
 showpane();
 break;
 default:
 break;
 }
 }
 cout<<setw(43)<<"你的最后成绩为:"<<panemax()<<endl;
 cout<<setw(60)<<"若要重新开始游戏请输入1,若要结束请输入0。"<<endl;
 cin>>makesure;
 while(makesure!=1&&makesure!=0)
 {
 cout<<"输入不正确,请重新输入!"<<endl;
 cin>>makesure;
 }
 }
 cout<<"再见!"<<endl;
 system("pause");

}

 

热门游戏 2048 C++ 源代码分享

标签:

原文地址:http://www.cnblogs.com/zendu/p/4987838.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!