C++ 實現2048遊戲樣本_C 語言

來源:互聯網
上載者:User

這遊戲前一段時間傳的很火,前幾天早上實在太無聊了,就決定把這遊戲自己也寫一個。

前後寫了一個多小時吧,大概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;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.