欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

超级简单推箱子小游戏 (简单代码和思路)

程序员文章站 2022-03-13 14:49:53
推箱子游戏演示代码展示#include#include#includeint 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},...

推箱子

游戏演示

超级简单推箱子小游戏 (简单代码和思路)

代码展示

#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步数:%d",cut);
		   return 0;
	   }
	  //根据数据的大小来判断当前的坐标上的情况
	  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;
	  }
}		
}

本文地址:https://blog.csdn.net/weixin_49198344/article/details/108173105