C/C++푸 시 박스 만 들 기 미니 게임

5736 단어 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;
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기