| 注册
请输入搜索内容

热门搜索

Java Linux MySQL PHP JavaScript Hibernate jQuery Nginx
jopen
11年前发布

2048 C++源代码by Reason

2048 C++源代码by Reason

 

以下是源代码:

/*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);      if(pane[i][j]==0)      cout<<setw(2)<<"|"<<setw(4)<<" ";     else      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)&&pane[i+1][j])     {      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)&&pane[i-1][j])     {      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)&&pane[i][j+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)&&pane[i][j-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:      if(testup()==1)      { upmove();       addnewnumberup();       system("cls");       showpane();      }      break;     case 4:      if(testdown()==1)      {       downmove();       addnewnumberdown();       system("cls");       showpane();      }      break;     case 1:      if(testleft()==1)      {       leftmove();       addnewnumberleft();       system("cls");       showpane();      }      break;     case 3:      if(testright()==1)      {       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");    return 0;  }

 本文由用户 jopen 自行上传分享,仅供网友学习交流。所有权归原作者,若您的权利被侵害,请联系管理员。
 转载本站原创文章,请注明出处,并保留原始链接、图片水印。
 本站是一个以用户分享为主的开源技术平台,欢迎各类分享!
 本文地址:https://www.open-open.com/lib/view/open1397013397028.html
源代码 C/C++开发