C++2048 게임 예시 구현

8554 단어 c + +2048
이 게임 은 얼마 전에 불 이 났 는데 며칠 전 아침 에 너무 지루 해서 이 게임 을 자신 도 쓰기 로 했 습 니 다.
앞 뒤로 한 시간 넘 게 썼 죠.한 300 줄 정도.복잡 한 알고리즘 은 없 지만 최적화 하기 가 귀 찮 지만 최적화 가 끝나 면 200 줄 이하 로 제어 할 수 있 을 것 같 아 요.관심 있 는 친 구 는 스스로 최적화 할 수 있 을 것 같 아 요.
설명:저 는 처음에 IOS APP 버 전의 TRHEES 를 했 는데 나중에 2048 을 했 습 니 다.둘 은 미 끄 러 지 는 규칙 에 있어 차이 가 있 습 니 다.본인 의 이 버 전 은 이 두 가지 결합 입 니 다.
마지막 으로 즐 거 운 시간 보 내세 요!

화면 이 추 해서 웃 지 않 기 를 바란다.
다음은 소스 코드 입 니 다.

/*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;
}

좋은 웹페이지 즐겨찾기