C/C++編寫推箱子小遊戲

本文實例為大傢分享瞭C/C++編寫推箱子小遊戲的具體代碼,供大傢參考,具體內容如下

我們用’ #’來代表墻,‘O’來代表箱子,’ * ‘代表終點,‘@’代表箱子已經到達終點,‘S來表示人’。
註意:W,A,S,D為方向鍵,而且要在英文格式下

運行示例:

以下為完整代碼:

/*

推箱子(示例二)


*/
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <conio.h>
int main()
{
 char a[12][12]={"##########",
     "##     ###",
                    "##O###   #",
                    "# S O  O #",
                    "# **# O ##",
                    "##**#   ##",
                    "##########",
                   };
    int x=3,y=2;
    int i;
    char ch;
    for(i=0;i<7;i++)
    puts(a[i]);
    
    while(a[4][2]!='@'||a[4][3]!='@'||a[5][2]!='@'||a[5][3]!='@')
    {
     
  ch=getch();
     if(ch=='s')
     {
         if(a[x+1][y]!='#'&&a[x+1][y]!='O'&&a[x+1][y]!='@') //如果隻有人,沒有箱子 
      {
       a[x][y]=' ';
       x++;
       a[x][y]='S';
   }
   else if(a[x+2][y]!='#'&&a[x+1][y]=='O'&&a[x+2][y]!='*') //如果是箱子和人一起走 
   {
    a[x][y]=' ';
    x++;
    a[x][y]='S';
    a[x+1][y]='O';
   }
   else if(a[x+2][y]!='#'&&(a[x+1][y]=='O'||a[x+1][y]=='@')&&a[x+2][y]=='*') //如果人和箱子一起走,並且前面是終點      
   {
    a[x][y]=' ';
    x++;
    a[x][y]='S'; 
    a[x+1][y]='@';
   }
  }
  
  if(ch=='w')
     {
      
      if(a[x-1][y]!='#'&&a[x-1][y]!='O'&&a[x-1][y]!='@') //如果隻有人,沒有箱子 
      {
       a[x][y]=' ';
       x--;
       a[x][y]='S';
       
   }
   else if(a[x-2][y]!='#'&&a[x-1][y]=='O'&&a[x-2][y]!='O') //如果是箱子和人一起走 
   {
    a[x][y]=' ';
    x--;
    a[x][y]='S';
    a[x-1][y]='O';

   }
   else if(a[x-2][y]!='#'&&(a[x-1][y]=='O'||a[x-1][y]=='@')&&a[x-2][y]=='*')  //如果人和箱子一起走,並且前面是終點      
   {
    a[x][y]=' ';
    x--;
    a[x][y]='S'; 
    a[x-1][y]='@';
   }
  }
  if(ch=='a')
     {
      
      if(a[x][y-1]!='#'&&a[x][y-1]!='O'&&a[x][y-1]!='@') //如果隻有人,沒有箱子 
      {
       a[x][y]=' ';
       y--;
       a[x][y]='S';
       
   }
   else if(a[x][y-2]!='#'&&a[x][y-1]=='O') //如果是箱子和人一起走 
   {
    a[x][y]=' ';
    y--;
    a[x][y]='S';
    a[x][y-1]='O';
   }
   else if(a[x][y-2]!='#'&&(a[x][y-1]=='O'||a[x][y-1]=='@')&&a[x][y-2]=='*') //如果人和箱子一起走,並且前面是終點      
   {
    a[x][y]=' ';
    y--;
    a[x][y]='S'; 
    a[x][y-1]='@';
   }
  }
  if(ch=='d')
     {
      
      if(a[x][y+1]!='#'&&a[x][y+1]!='O'&&a[x][y+1]!='@') //如果隻有人,沒有箱子 
      {
       a[x][y]=' ';
       y++;
       a[x][y]='S';
       
   }
   else if(a[x][y+2]!='#'&&a[x][y+1]=='O'&&a[x][y+2]!='O') //如果是箱子和人一起走 
   {
    a[x][y]=' ';
    y++;
    a[x][y]='S';
    a[x][y+1]='O';
   }
   else if(a[x][y+2]!='#'&&(a[x][y+1]=='O'||a[x][y+1]=='@')&&a[x][y+2]=='*'&&a[x][y+2]!='O')   //如果人和箱子一起走,並且前面是終點      
   {
    a[x][y]=' ';
    y++;
    a[x][y]='S'; 
    a[x][y+1]='@';
   }
  }
  if(a[4][2]!='@'&&a[4][2]!='S'&&a[4][2]!='*')
     {
      a[4][2]='*';
  }
  if(a[4][3]!='@'&&a[4][3]!='S'&&a[4][3]!='*')
     {
      a[4][3]='*';
  }
  if(a[5][2]!='@'&&a[5][2]!='S'&&a[5][2]!='*')
     {
      a[5][2]='*';
  }
  if(a[5][3]!='@'&&a[5][3]!='S'&&a[5][3]!='*')
     {
      a[5][3]='*';
  }
  if(a[1][2]=='O'||a[1][6]=='O'||a[2][8]=='O'||a[3][8]=='O'||a[5][5]=='O'||a[5][7]=='O')              //判斷失敗的情況 
  {
   break;
  }
  system("cls");
  for(i=0;i<7;i++)
     puts(a[i]);
 }
 system("cls");
 if(a[4][2]!='@'||a[4][3]!='@'||a[5][2]!='@'||a[5][3]!='@')
    printf("YOU LOSE!");
    else
    printf("YOU WIN!");
    Sleep(3000);
    
 return 0;
}

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: