HDU-1253 胜利大逃亡 (bfs-时间???)

Ignatius被魔王抓走了,有一天魔王出差去了,这可是Ignatius逃亡的好机会.

魔王住在一个城堡里,城堡是一个ABC的立方体,可以被表示成A个B*C的矩阵,刚开始Ignatius被关在(0,0,0)的位置,离开城堡的门在(A-1,B-1,C-1)的位置,现在知道魔王将在T分钟后回到城堡,Ignatius每分钟能从一个坐标走到相邻的六个坐标中的其中一个.现在给你城堡的地图,请你计算出Ignatius能否在魔王回来前离开城堡(只要走到出口就算离开城堡,如果走到出口的时候魔王刚好回来也算逃亡成功),如果可以请输出需要多少分钟才能离开,如果不能则输出-1.

Input

输入数据的第一行是一个正整数K,表明测试数据的数量.每组测试数据的第一行是四个正整数A,B,C和T(1<=A,B,C<=50,1<=T<=1000),它们分别代表城堡的大小和魔王回来的时间.然后是A块输入数据(先是第0块,然后是第1块,第2块…),每块输入数据有B行,每行有C个正整数,代表迷宫的布局,其中0代表路,1代表墙.(如果对输入描述不清楚,可以参考Sample Input中的迷宫描述,它表示的就是上图中的迷宫)

特别注意:本题的测试数据非常大,请使用scanf输入,我不能保证使用cin能不超时.在本OJ上请使用Visual C++提交.

Output

对于每组测试数据,如果Ignatius能够在魔王回来前离开城堡,那么请输出他最少需要多少分钟,否则输出-1.

Sample Input

1
3 3 4 20
0 1 1 1
0 0 1 1
0 1 1 1
1 1 1 1
1 0 0 1
0 1 1 1
0 0 0 0
0 1 1 0
0 1 1 0

Sample Output

11

//vis数组在push前++ (省时)
//减少函数调用(省时)

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<functional>
#include"string"
#include<map>
#include"queue"
using namespace std;
const int maxn = 55;
int g[maxn][maxn][maxn],vis[maxn][maxn][maxn];
int a, b, c, t;
typedef struct node {
	int x, y, z, st;
}node;
int bfs() {
	queue<node> q;
	memset(vis, 0, sizeof(vis));
	vis[0][0][0]++;
	q.push({ 0,0,0,0 });
	while (!q.empty()) {
		node p = q.front();
		q.pop();
		if (p.st > t) return -1;
		if (p.x == a - 1 && p.y == b - 1 && p.z == c - 1) return p.st;
		
		if ((!vis[ p.x + 1][p.y][p.z] && p.x + 1 >= 0 &&  p.x + 1 < a && p.y >= 0 && p.y < b && p.z >= 0 && p.z < c)&&g[p.x + 1][p.y][p.z] == 0  ){ 
			q.push({ p.x + 1,p.y,p.z,p.st + 1 });
			vis[ p.x + 1][p.y][p.z]++; 
		}
		if ((!vis[ p.x ][p.y+ 1][p.z] && p.x  >= 0 &&  p.x  < a && p.y+ 1 >= 0 && p.y+ 1 < b && p.z >= 0 && p.z < c)&&g[p.x][p.y + 1][p.z] == 0  ){ 
			q.push({ p.x,p.y + 1,p.z,p.st + 1 });
			vis[ p.x ][p.y+ 1][p.z]++; 
		}
		if ((!vis[ p.x ][p.y][p.z+ 1] && p.x  >= 0 &&  p.x  < a && p.y >= 0 && p.y < b && p.z+ 1 >= 0 && p.z+ 1 < c)&&g[p.x][p.y][p.z + 1] == 0  ){ 
			q.push({ p.x,p.y,p.z + 1,p.st + 1 });
			vis[ p.x ][p.y][p.z+ 1]++; 
		}
		if ((!vis[ p.x - 1][p.y][p.z] && p.x - 1 >= 0 &&  p.x -1 < a && p.y >= 0 && p.y < b && p.z >= 0 && p.z < c)&&g[p.x - 1][p.y][p.z] == 0  ) { 
			q.push({ p.x - 1,p.y,p.z,p.st + 1 });
			vis[ p.x - 1][p.y][p.z]++; 
		}
		if ((!vis[ p.x ][p.y- 1][p.z] && p.x  >= 0 &&  p.x  < a && p.y - 1>= 0 && p.y- 1 < b && p.z >= 0 && p.z < c)&&g[p.x][p.y - 1][p.z] == 0  ){ 
			q.push({ p.x,p.y - 1,p.z,p.st + 1 });
			vis[ p.x ][p.y- 1][p.z]++; 
		}
		if ((!vis[ p.x ][p.y][p.z- 1] && p.x  >= 0 &&  p.x  < a && p.y >= 0 && p.y < b && p.z- 1 >= 0 && p.z- 1 < c)&&g[p.x][p.y][p.z - 1] == 0  ){ 
			q.push({ p.x,p.y,p.z - 1,p.st + 1 });
			vis[ p.x ][p.y][p.z- 1]++; 
		}
	}
	return -1;
}

int main()
{
	int tt = 0;
	scanf("%d", &tt);
	while (tt--) {
		scanf("%d%d%d%d", &a,&b,&c,&t);
		for (int i = 0; i < a; i++) {
			for (int k = 0; k < b; k++) {
				for (int j = 0; j < c; j++) {
					scanf("%d",&g[i][k][j]);
				}
			}

		}
		printf("%d\n", bfs());
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
水资源是人类社会的宝贵财富,在生活、工农业生产中是不可缺少的。随着世界人口的增长及工农业生产的发展,需水量也在日益增长,水已经变得比以往任何时候都要珍贵。但是,由于人类的生产和生活,导致水体的污染,水质恶化,使有限的水资源更加紧张。长期以来,油类物质(石油类物质和动植物油)一直是水和土壤中的重要污染源。它不仅对人的身体健康带来极大危害,而且使水质恶化,严重破坏水体生态平衡。因此各国都加强了油类物质对水体和土壤的污染的治理。对于水中油含量的检测,我国处于落后阶段,与国际先进水平存在差距,所以难以满足当今技术水平的要求。为了取得具有代表性的正确数据,使分析数据具有与现代测试技术水平相应的准确性和先进性,不断提高分析成果的可比性和应用效果,检测的方法和仪器是非常重要的。只有保证了这两方面才能保证快速和准确地测量出水中油类污染物含量,以达到保护和治理水污染的目的。开展水中油污染检测方法、技术和检测设备的研究,是提高水污染检测的一条重要措施。通过本课题的研究,探索出一套适合我国国情的水质污染现场检测技术和检测设备,具有广泛的应用前景和科学研究价值。 本课题针对我国水体的油污染,探索一套检测油污染的可行方案和方法,利用非分散红外光度法技术,开发研制具有自主知识产权的适合国情的适于野外便携式的测油仪。利用此仪器,可以检测出被测水样中亚甲基、甲基物质和动植物油脂的污染物含量,为我国众多的环境检测站点监测水体的油污染状况提供依据。
### 内容概要 《计算机试卷1》是一份综合性的计算机基础和应用测试卷,涵盖了计算机硬件、软件、操作系统、网络、多媒体技术等多个领域的知识点。试卷包括单选题和操作应用两大类,单选题部分测试学生对计算机基础知识的掌握,操作应用部分则评估学生对计算机应用软件的实际操作能力。 ### 适用人群 本试卷适用于: - 计算机专业或信息技术相关专业的学生,用于课程学习或考试复习。 - 准备计算机等级考试或职业资格认证的人士,作为实战演练材料。 - 对计算机操作有兴趣的自学者,用于提升个人计算机应用技能。 - 计算机基础教育工作者,作为教学资源或出题参考。 ### 使用场景及目标 1. **学习评估**:作为学校或教育机构对学生计算机基础知识和应用技能的评估工具。 2. **自学测试**:供个人自学者检验自己对计算机知识的掌握程度和操作熟练度。 3. **职业发展**:帮助职场人士通过实际操作练习,提升计算机应用能力,增强工作竞争力。 4. **教学资源**:教师可以用于课堂教学,作为教学内容的补充或学生的课后练习。 5. **竞赛准备**:适合准备计算机相关竞赛的学生,作为强化训练和技能检测的材料。 试卷的目标是通过系统性的题目设计,帮助学生全面复习和巩固计算机基础知识,同时通过实际操作题目,提高学生解决实际问题的能力。通过本试卷的学习与练习,学生将能够更加深入地理解计算机的工作原理,掌握常用软件的使用方法,为未来的学术或职业生涯打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值