`

南阳理工OJ 284 坦克大战 宽度优先遍历

 
阅读更多
/*
比较简单的一道题,只要细心,思路清楚,基本都可以一遍过的
先把在地图上的实物数量化,墙是2,路是1,出界、河、铁墙都是-1
表示不能走。
然后用宽度遍历,起始点为队头,每次遍历上下左右四个方向
如果地图为-1,就不操作
如过地图不为-1,但没有遍历过,那么这块地图的步数应该是
队头地图的步数加上这块地图需要的步数。
如过地图不为-1,遍历过,那么这块地图的步数应该是
队头地图的步数加上这块地图需要的步数,和原来这块地图的
步数相比,最小的步数。
*/
#include<iostream>
#include<string.h>
using namespace std;
int n,m;
int map[300+10][300+10];
int result[300+10][300+10];
int queue[100000];
int base,top;
int fang[4][2]={0,1,0,-1,1,0,-1,0};
int main()
{
//	freopen("in.txt","r",stdin);
	int i,j,x,y,x1,y1,resx,resy;
	char c;
	while(cin>>n>>m,n)
	{
		top=base=0;
		memset(map,-1,sizeof(map));
		memset(result,-1,sizeof(result));
		for(i=1;i<=n;i++)
			for(j=1;j<=m;j++)
			{
				cin>>c;
				if(c=='Y')
				{
					map[i][j]=0;
					result[i][j]=0;
					queue[top++]=i*1000+j;//起始坐标入队
				}
				else if(c=='B')map[i][j]=2;
				else if(c=='E')map[i][j]=1;
				else if(c=='T')resx=i,resy=j,map[i][j]=1;//标记要求的坐标
			}
		while(base!=top)
		{
			for(i=0;i<4;i++)
			{
				x=queue[base]/1000;
				x1=x+fang[i][0];
				y=queue[base]%1000;
				y1=y+fang[i][1];//算出横纵坐标
				if(map[x1][y1]==-1)continue;//如果在地图上走不成就继续
				if(result[x1][y1]==-1||(result[x1][y1]>result[x][y]+map[x1][y1]))
				{//如果没有走过或者走过但不是最优,就更新为最优,继续入队
					result[x1][y1]=result[x][y]+map[x1][y1];
					queue[top++]=x1*1000+y1;
				}
			}
			base++;//判断完一个出队一个
		}
		if(result[resx][resy]==-1)cout<<"-1\n";
		else cout<<result[resx][resy]<<endl;
	}
	return(0);
}

 

/*
也可以用优先队列来做,速度应该会快一点;
每次找最短的路走,走一个,就把这一个路
标记一下,下一次就不用走这条路.
其他的和上一个方法差不多
*/
#include<iostream>
#include<string.h>
#include<queue>
using namespace std;
char map[300+2][300+2];
char fang[4][2]={0,1,0,-1,1,0,-1,0};
struct node
{
	short x,y;
	int date;
}a,b;
bool operator<(const node &a,const node &b)//重载运算符
{
	return(a.date>b.date);
}
priority_queue<node>q;
int n,m;
int main()
{
//	freopen("in.txt","r",stdin);
	int i,j,x,y,f;
	char c;
	while(cin>>n>>m,n)
	{
		memset(map,-1,sizeof(map));
		for(i=1;i<=n;i++)
			for(j=1;j<=m;j++)
			{
				cin>>c;
				if(c=='Y')
				{
					map[i][j]=-1;
					a.x=i;a.y=j;a.date=0;q.push(a);
				}
				else if(c=='B')map[i][j]=2;
				else if(c=='E')map[i][j]=1;
				else if(c=='T')map[i][j]=1,x=i,y=j;
			}
		while(!q.empty())
		{
			a=q.top();
			q.pop();
			f=0;
			for(i=0;i<4;i++)
			{
				b.x=a.x+fang[i][0];
				b.y=a.y+fang[i][1];
				if(map[b.x][b.y]==-1)continue;
				b.date=a.date+map[b.x][b.y];
				map[b.x][b.y]=-1;//标记为不能走
				if(b.x==x&&b.y==y){f=1;break;}//找到就退出
				q.push(b);
			}
			if(f)break;
		}
		if(f)cout<<b.date<<endl;//输出
		else cout<<"-1\n";
		while(!q.empty())q.pop();//清空队列
	}
	return(0);
}

 

分享到:
评论

相关推荐

    南阳理工oj离线题库

    南阳理工oj离线题库是为编程爱好者和学习者提供的一种资源,主要用于练习和提高编程技能。这个离线题库通常包含多种类型的编程题目,涵盖了数据结构、算法、计算机科学基础等多个方面。在这个环境中,用户可以不受...

    南阳理工学院OJ_个人AC代码包(Java提交)

    【南阳理工学院OJ_个人AC代码包(Java提交)】是针对Java初学者的一份宝贵资源,它包含了参与ACM国际大学生程序设计竞赛(ICPC)时在南阳理工学院在线评测系统(OJ)上获得正确答案的代码实例。这些代码展示了如何用...

    南阳理工学院OJ第1版解题报告V1.0.pdf

    ### 南阳理工学院OJ第1版解题报告概览 #### 1. A+B Problem 虽然解题思路在报告中被省略,但我们可以推测这是一个基础的数学加法问题,涉及到数字输入与基本算术操作。此类题目旨在测试初学者对编程语言基本输入...

    南阳理工oj stl练习ac代码

    南阳理工学院的OJ(Online Judge)平台为学生提供了丰富的STL练习题目,通过AC(Accepted,表示代码正确通过所有测试用例)的代码,我们可以学习到STL在实际问题解决中的应用。 1. 容器: STL包含多种容器,如...

    湖南理工oj题解(学习用)-共230道题

    【标题】:“湖南理工oj题解(学习用)-共230道题”揭示了这是一个针对湖南理工大学在线编程竞赛平台(Online Judge,简称OJ)的题解集合,包含了230个不同题目。这类资源通常由参赛者或者经验丰富的程序员整理,...

    哈理工oj 1084百步穿杨

    哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案哈理工OJ1084答案

    湖南理工学院OJ-小鱼比可爱

    湖南理工学院小鱼比可爱OJ题

    oj刷题 西安理工大学学生在线实验系统编程题答案(超级详细)

    这个“oj刷题”压缩包文件很可能是包含了西安理工大学在线实验系统中的一些典型题目,包括但不限于排序算法(如冒泡排序、快速排序、归并排序)、搜索算法(如二分查找、深度优先搜索、广度优先搜索)、图论问题(如...

    ACM在线评测系统 NYOJ 题库 离线看题网页版 nyoj

    NYOJ,全称为南阳理工学院在线评测系统(Nanyang Institute of Technology Online Judge),是为ACM(国际大学生程序设计竞赛)以及其他编程爱好者提供的一种在线编程练习平台。该系统支持用户提交代码并进行实时...

    基于Laravel 5.0的OJ题解网站 , 目前涵盖安科OJ,南阳OJ,杭电OJ ,北大OJ,浙大OJ.zip

    【描述】中提到的“目前涵盖安科OJ,南阳OJ,杭电OJ,北大OJ,浙大OJ”意味着这个题解网站已经集成了多个知名OJ平台的题目,用户可以在一个统一的平台上找到这些不同OJ的题目并查看解决方案。安科OJ、南阳OJ、杭电OJ...

    DFS:depth first search深度优先搜索(迷宫寻路) BFS:breadth first search宽度优先搜

    深度优先搜索(DFS,Depth First Search)和宽度优先搜索(BFS,Breadth First Search)是图论和算法中的两种基本搜索策略,常用于解决迷宫寻路、树遍历以及网络爬虫等问题。这两种算法各有其特点,适用于不同的场景...

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    趣味题:柱状图排序 西安理工大学学生在线实验系统 oj

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答

    竞赛题集南阳OJ部分习题及解答其他oj试题及解答提取方式是百度网盘分享地址

    山东理工大学2016级OJ题1832

    【知识点详解】 1. **C 语言基础**:在这些题目中,主要使用了 C 语言作为编程语言,包括变量声明、输入输出、循环结构、函数定义与调用等基本概念。例如,`scanf` 用于从标准输入读取数据,`printf` 用于输出结果...

    湖南理工学院OJ-阶乘求和-定义函数

    湖南理工学院OJ-阶乘求和-定义函数

    北大oj 题目分类

    1. **图遍历**:深度优先遍历(DFS)和广度优先遍历(BFS),如`poj1094`的拓扑排序。 2. **最短路径算法**:Dijkstra、Bellman-Ford、Floyd、堆优化的Dijkstra,用于求解两点间的最短路径,如`poj1860`。 3. **最小...

    湖南理工学院Oj-等腰三角形-嵌套循环

    湖南理工学院Oj-等腰三角形-嵌套循环

    hustoj - 流行的OJ系统,跨平台、易安装、有题库

    【标题】"hustoj" 是一款流行的在线判题系统(Online Judge,简称OJ),它主要用于教育和考试场景,支持教学管理和编程竞赛。这款系统以其跨平台、易安装和包含题库的特点受到广泛欢迎。 【核心知识点】 1. **在线...

    郑州轻工业oj;C语言200道题压缩包

    郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;郑州轻工业oj;C语言200道题压缩包;...

    软件工程课件--厦门理工

    《软件工程:厦门理工学院深度解析》 软件工程是一门涉及软件开发全过程的学科,它不仅关注编程技术,更注重软件开发的系统性、规范性和可维护性。厦门理工学院的这一系列课件,无疑为学习者提供了一个全面了解和...

Global site tag (gtag.js) - Google Analytics