当前位置: 首页 > article >正文

用C语言实现推箱子小游戏

 

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

//1.绘制游戏地图
void DrawMap(int Map[8][8])  //函数封装,方便使用  
{
	for (int i = 0; i < 8; i++)
	{
		for (int j = 0; j < 8; j++)
		{
			switch (Map[i][j])
			{
			case 0:printf("  "); break;//空地

			case 1:printf("■"); break;//墙壁

			case 3:printf("☆"); break;//目的地

			case 4:printf("□"); break;//箱子

			case 6:printf("♀"); break;//人物

			case 7:printf("□"); break;//箱子与目的地重合,显示箱子

			case 9:printf("♀"); break;//人和目的地重合,显示人



			}
		}
		printf("\n");
	}
}
int main()
{                              //要设置多个关卡,需要用到多维数组
	int Map[8][8] = {
		0,0,1,1,1,0,0,0,
		0,0,1,3,1,0,0,0,
		0,0,1,0,1,1,1,1,
		1,1,1,4,0,4,3,1,   //3,4向上  
		1,3,0,4,6,1,1,1,   //4,4人    4,3向左,4,5向右
		1,1,1,1,4,1,0,0,   //5,4向下
		0,0,0,1,3,1,0,0,
		0,0,0,1,1,1,0,0,
	};


	//多次输入,用循环
	while (1) {
		//清屏
		system("cls");  //清屏,需要头文件stdlib.h
		DrawMap(Map);
		int count = 0;//计算分数
		//2.移动角色
		int i, j;
		for (i = 0; i < 8; i++)
		{
			for (j = 0; j < 8; j++)
			{
				if (Map[i][j] == 6 || Map[i][j] == 9)//只会退出j循环
					break;
			}
			if (Map[i][j] == 6 || Map[i][j] == 9)//9表示人物与目的地重合
				break;
		}

		printf("角色坐标:(%d,%d)\n", i, j);

		//3.从键盘获取字符,确定人物移动的方位

		int input = getch();//从键盘那获取字符存储到input中
		switch (input)
		{
		case 'w':
			//判断角色前方是空地0或者是目的地3,表示人物可以向上移动
			if (Map[i - 1][j] == 0 || Map[i - 1][j] == 3)    //行变列不变,即i-1
			{
				//移动角色
				Map[i - 1][j] += 6;//0+6=6,3+6=9
				Map[i][j] -= 6;
			}
			//判断角色的前方是箱子,或者箱子在目的地
			else if (Map[i - 1][j] == 4 || Map[i - 1][j] == 7)
			{
				//箱子前面的内容i-2,若为空地0或者目的地3,表示人物可以箱子推着走
				if (Map[i - 2][j] == 0 || Map[i - 2][j] == 3)
				{
					Map[i - 2][j] += 4;//0+4=4  3+4=7
					Map[i - 1][j] += 2;//4+2=6  7+2=9
					Map[i][j] -= 6;//6-6=0  9-6=3

				}
			}
			break;
		case 's':
			//判断角色后面是空地0或者是目的地3,表示人物可以向下移动
			if (Map[i + 1][j] == 0 || Map[i + 1][j] == 3)    //行变列不变,即i-1
			{
				//移动角色
				Map[i + 1][j] += 6;//0+6=6,3+6=9
				Map[i][j] -= 6;
			}
			//判断角色的前方是箱子,或者箱子在目的地
			else if (Map[i + 1][j] == 4 || Map[i + 1][j] == 7)
			{
				//箱子前面的内容i-2,若为空地0或者目的地3,表示人物可以箱子推着走
				if (Map[i + 2][j] == 0 || Map[i + 2][j] == 3)
				{
					Map[i + 2][j] += 4;//0+4=4  3+4=7
					Map[i + 1][j] += 2;//4+2=6  7+2=9
					Map[i][j] -= 6;//6-6=0  9-6=3

				}
			}break;
		case 'a':
			//判断角色左边是空地0或者是目的地3,表示人物可以向左移动
			if (Map[i][j - 1] == 0 || Map[i][j - 1] == 3)    //行变列不变,即i-1
			{
				//移动角色
				Map[i][j - 1] += 6;//0+6=6,3+6=9
				Map[i][j] -= 6;
			}
			//判断角色的左边是箱子,或者箱子在目的地
			else if (Map[i][j - 1] == 4 || Map[i][j - 1] == 7)
			{
				//箱子前面的内容i-2,若为空地0或者目的地3,表示人物可以箱子推着走
				if (Map[i][j - 2] == 0 || Map[i][j - 2] == 3)
				{
					Map[i][j - 2] += 4;//0+4=4  3+4=7
					Map[i][j - 1] += 2;//4+2=6  7+2=9
					Map[i][j] -= 6;//6-6=0  9-6=3

				}
			}break;
		case 'd':
			//判断角色右边是空地0或者是目的地3,表示人物可以向右移动
			if (Map[i][j + 1] == 0 || Map[i][j + 1] == 3)    //行变列不变,即i-1
			{
				//移动角色
				Map[i][j + 1] += 6;//0+6=6,3+6=9
				Map[i][j] -= 6;
			}
			//判断角色的左==右边是箱子,或者箱子在目的地
			else if (Map[i][j + 1] == 4 || Map[i][j + 1] == 7)
			{
				//箱子前面的内容i-2,若为空地0或者目的地3,表示人物可以箱子推着走
				if (Map[i][j + 2] == 0 || Map[i][j + 2] == 3)
				{
					Map[i][j + 2] += 4;//0+4=4  3+4=7
					Map[i][j + 1] += 2;//4+2=6  7+2=9
					Map[i][j] -= 6;//6-6=0  9-6=3

				}
			}
			break;

		}

		for (int m = 0; m < 8; m++)
		{
			for (int n = 0; n < 8; n++)
			{
				if (Map[m][n] == 7)
					count++;
			}
		}
		if (count == 4) {
			system("cls");
			DrawMap(Map);

			printf("你过关!!!\n");
			return 0;
		}
		//DrawMap(Map);


	}//}为while的循环
	return 0;
}

注:以上代码为推箱子小游戏的最初代码,未配图.


http://www.kler.cn/a/500580.html

相关文章:

  • 大疆C++开发面试题及参考答案
  • iOS - runtime总结
  • 【Apache Paimon】-- 13 -- 利用 paimon-flink-action 同步 mysql 表数据
  • 【Linux】文件 文件描述符fd
  • windows C#-泛型方法
  • Python----Python基础(字符串,列表,元组,字典,集合的总结)
  • 【CSS】设置滚动条样式
  • 【源码解析】Java NIO 包中的 MappedByteBuffer
  • 一文详解YOLOv8多模态目标检测(可见光+红外图像,基于Ultralytics官方代码实现),轻松入门多模态检测领域!
  • 金融项目实战 03|JMeter脚本实现手工接口测试
  • 【微信小程序】回到顶部图标-页面滚动事件 | 漫画-综合实训
  • 深度学习中的EMA技术:原理、实现与实验分析
  • 计算机网络之---传输层的功能
  • conntrack iptables 安全组
  • Oracle 使用dbms_stats.gather_table_stats来进行表analyse,收集表统计信息
  • 《零基础Go语言算法实战》【题目 2-7】defer 关键字特性
  • spring boot 支持jsonp请求
  • 阿里云发现后门webshell,怎么处理,怎么解决?
  • React - router的使用 结合react-redux的路由守卫
  • 依赖网络系统混合级联故障下系统可靠性提高与弹性的组合优化
  • 网络安全 | Web安全常见漏洞和防护经验策略
  • 苍穹外卖及软件开发介绍
  • 基于 B2C 的网上拍卖系统:秒杀与竞价功能的实现
  • ip归属地和手机号是一个地址吗