溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C++實現(xiàn)推箱子游戲的案例

發(fā)布時間:2020-08-25 09:52:15 來源:億速云 閱讀:296 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹C++實現(xiàn)推箱子游戲的案例,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

C++實現(xiàn)簡單推箱子的具體代碼具體內(nèi)容如下

游戲演示

C++實現(xiàn)推箱子游戲的案例

代碼展示

#include<stdio.h>
#include<stdlib.h>
#include<getch.h>

int main(int argc,const char*argv[])
{
 int cut=0;
 int a[8][8]={
   {0,0,3,3,3,3,0,0}, 
   {0,0,3,5,5,3,0,0}, 
   {0,0,3,0,5,3,0,0}, 
   {0,3,0,0,4,5,3,0}, 
   {3,3,0,4,0,0,3,3}, 
   {3,0,0,3,4,4,0,3}, 
   {3,0,0,2,0,0,0,3}, 
   {3,3,3,3,3,3,3,3}}; 
 int x=6,y=3;
 for(;;)
 {
 int cunt=0;
 system("clear");
 for(int i=0;i<8;i++)
 {
  for(int j=0;j<8;j++)
  {
  if(a[i][j]==9)
  {
  cunt++;
  }
  switch(a[i][j])
  {
  case 0:printf(" ");break;
  case 2:printf("@ ");break;//人
  case 3:printf("# ");break;//墻
  case 4:printf("$ ");break;//箱子
  case 5:printf("o ");break;//目標位置
  case 7:printf("@ ");break;
  case 9:printf("$ ");break;
  }
  }
  printf("\n");
 }
 if(4==cunt)
 {
  printf("成功\n步數(shù):%d",cut);
  return 0;
 }
 //根據(jù)數(shù)據(jù)的大小來判斷當前的坐標上的情況
 switch(getch())
 {
 case 183:
   if(0!=x&&3==a[x-1][y])
  {
  a[x][y]=2;
  }
  else if(5==a[x-1][y]||0==a[x-1][y])
  {
  a[x][y]-=2;
  a[x-1][y]+=2;
  x--;
  cut++;
  }
  else if((5==a[x-2][y]||0==a[x-2][y])&&(4==a[x-1][y]||9==a[x-1][y]))
  {
  a[x-2][y]+=4;
  a[x-1][y]-=4;
  a[x-1][y]+=2;
  a[x][y]-=2;
  x--;cut++;
  }break;
 case 184:
  if(0!=x&&3==a[x+1][y])
  {
  a[x][y]=2;
  }
  else if((5==a[x+1][y])||(0==a[x+1][y]))
  {
  a[x][y]-=2;
  a[x+1][y]+=2;
  x++;cut++;
  }
  else if((5==a[x+2][y]||0==a[x+2][y])&&(4==a[x+1][y]||9==a[x+1][y]))
  {
  a[x+2][y]+=4;
  a[x+1][y]-=4;
  a[x+1][y]+=2;
  a[x][y]-=2;
  x++;cut++;
  }break;
 case 185:
   if(0!=x&&3==a[x][y+1])
  {
  a[x][y]=2;
  }
  else if(5==a[x][y+1]||0==a[x][y+1])
  {
  a[x][y]-=2;
  a[x][y+1]+=2;
  y++;cut++;
  }
  else if((0==a[x][y+2]||5==a[x][y+2])&&(4==a[x][y+1]||9==a[x][y+1]))
  {
  a[x][y+2]+=4;
  a[x][y+1]-=4;
  a[x][y+1]+=2;
  a[x][y]-=2;
  y++;cut++;
  }break;
 case 186:
   if(0!=x&&3==a[x][y-1])
  {
  a[x][y]=2;
  }
  else if(5==a[x][y-1]||0==a[x][y-1])
  {
  a[x][y]-=2;
  a[x][y-1]+=2;
  y--;cut++;
  }
  else if((0==a[x][y-2]||5==a[x-1][y])&&(4==a[x][y-1]||9==a[x][y-1]))
  {
  a[x][y-2]+=4;
  a[x][y-1]-=4;
  a[x][y-1]+=2;
  a[x][y]-=2;
  y--;cut++;
  }break;
 }
} 
}

以上是C++實現(xiàn)推箱子游戲的案例的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI