nyoj 1100 WAJUEJI which home strong!
WAJUEJI which home strong!
- 描述
- 
在一个山沟里,姐弟俩同时考上了大学。但由于家里拮据,所以这并不是什么好消息。父亲对孩子说:我就是砸锅卖铁也要把你们姐俩供出来。 当时的姐姐已经决定放弃上学的机会。 没想到第二天天还没亮,弟弟就偷偷带著几件破衣服和几个乾巴馒头走了,在姐姐枕边留下一个纸条: 姐,你别愁了,考上大学不容易,我出去打工供你。弟。 姐姐握著那张字条,趴在炕上,失声痛哭。 那一年,弟弟17岁,姐姐20岁。 姐姐用父亲满村子借的钱和弟弟在工地裏搬水泥挣的钱终於读到了大三。 一天姐姐正在寝室里看书,同学跑进来对姐姐说,有个老乡在找你。姐姐很纳闷,走出去后,远远地看见弟弟,穿著满身是水泥和沙子的工作服。姐姐说,你怎么和我同学说你是我老乡啊? 他笑著说,你看我穿的这样,说是你弟,你同学还不笑话你? 姐姐鼻子一酸,眼泪就落了下来。弟弟赶忙为姐姐擦掉眼泪,说:姐,你别哭,我这次来是想让你帮我打听一下,学挖掘机哪家强? 在你的帮助下,弟弟踏上了去蓝翔的路。 那么问题就来了。  
- 输入
- 第一个数T,T组测试数据。
 两个数 n, m; ( 0< n , m <= 100 ) 表示一个h行m列的二维地图。
 接下来n行每行m 个字符。
 ‘s’ 表示弟弟目前所在位置。
 ‘# ’表示此处为一座山。为了节省体力,不从此处通行。
 从‘A’-‘Z’表示各地的经济水平,对应1-26,路过对应字符的地区需要交对应的生活费。
 ‘l’表示蓝翔技校的所在地。
 s 与 l 均为小写字母。
 弟弟只能走四个方向。
- 输出
- 输出一个数表示弟弟到达蓝翔需要的生活费最小是多少。
 如果不能到达,输出 -1。
- 样例输入
- 
3 
 3 5
 #sVGF
 A##ZA
 lCDBC
 3 3
 sAB
 ABS
 ABl
 3 3
 s#B
 ###
 ABl
- 样例输出
- 
48 
 4
 -1#include<stdio.h> 
 #include<string.h>
 #include<algorithm>
 #include<queue>
 #define MAX 110
 using namespace std;
 int n,m;
 int vis[MAX][MAX];
 char map[MAX][MAX];
 int x1,x2,y1,y2;
 struct node
 {
 int x;
 int y;
 int step;
 friend bool operator < (node a,node b)
 {
 return a.step>b.step;
 }
 };
 void bfs(int x1,int y1,int x2,int y2)
 {
 int i,j,ok=0;
 int move[4][2]={0,1,0,-1,1,0,-1,0};
 priority_queue<node>q;
 node beg,end;
 beg.x=x1;
 beg.y=y1;
 beg.step=0;
 q.push(beg);
 while(!q.empty())
 {
 end=q.top();
 q.pop();
 if(end.x==x2&&end.y==y2)
 {
 ok=1;
 break;
 }
 for(i=0;i<4;i++)
 {
 beg.x=end.x+move[i][0];
 beg.y=end.y+move[i][1];
 if(!vis[beg.x][beg.y]&&beg.x>=0&&beg.x<n&&beg.y>=0&&beg.y<m&&map[beg.x][beg.y]!='#')
 {
 if(map[beg.x][beg.y]>='A'&&map[beg.x][beg.y]<='Z')
 beg.step=end.step+map[beg.x][beg.y]-'A'+1;
 else
 beg.step=end.step;
 vis[beg.x][beg.y]=1;
 q.push(beg);
 }
 }
 }
 if(ok)
 printf("%d\n",end.step);//这里输出时要注意是输出beg.step还是end.step
 else
 printf("-1\n");
 }
 int main()
 {
 int j,i;
 int t;
 scanf("%d",&t);
 while(t--)
 {
 scanf("%d%d",&n,&m);
 for(i=0;i<n;i++)
 {
 scanf("%s",map[i]);
 }
 for(i=0;i<n;i++)
 {
 for(j=0;j<m;j++)
 {
 if(map[i][j]=='s')
 {
 x1=i;y1=j;
 }
 if(map[i][j]=='l')
 {
 x2=i;y2=j;
 }
 }
 }
 memset(vis,0,sizeof(vis));
 bfs(x1,y1,x2,y2);
 }
 return 0;
 }
nyoj 1100 WAJUEJI which home strong!的更多相关文章
- WAJUEJI which home strong!nyoj
		WAJUEJI which home strong! 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 在一个山沟里,姐弟俩同时考上了大学.但由于家里拮据,所以这并不是 ... 
- NYoj WAJUEJI which home strong!(简单搜索)
		题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=1100 这道题,自己初写搜索,给学长气的只打我,Orz....... 搜索的思路要理 ... 
- WAJUEJI which home strong!
		算法:搜索+优先队列 描述 在一个山沟里,姐弟俩同时考上了大学.但由于家里拮据,所以这并不是什么好消息.父亲对孩子说:我就是砸锅卖铁也要把你们姐俩供出来. 当时的姐姐已经决定放弃上学的机会. 没想到第 ... 
- nyoj--1100--WAJUEJI which home strong!(bfs)
		WAJUEJI which home strong! 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 在一个山沟里,姐弟俩同时考上了大学.但由于家里拮据,所以这并不是什么 ... 
- Weak is not weak,Strong is not strong
		问题 今天做浏览器Controller的时候,碰到了一个奇怪的问题:每次pop浏览器controller之后,等几秒,总会碰到类似下面的错误(其中的xxxController就是浏览器或继承他的子类C ... 
- python入门:输出1-100之内的所有奇数和偶数(自写)
		#!/urs/bin/env python # -*- coding:utf-8 -*- #输出1-100之内的所有奇数和偶数(自写) """ 给x赋值等于1,wehil ... 
- datatables使用总结篇
		<!doctype html> <html> <head> <meta charset="gbk"/> <meta name= ... 
- php学习,一个简单的Calendar(2) 一个简单的活动页面
		有了前面的基础,后面就是将页面展示出来. 预览图如下:1号和31号分别有活动,会一并显示出来 这里需要搞定几个问题,一个就是数据库的连接,我们用\sys\class\class.db_connec ... 
- AJAX的简洁写法
		// ajax操作 $('#btn').on('click',function(){ var url = "{:url('confirm')}"; var actual_money ... 
随机推荐
- ci 用本身 email 类发 email
			//比如 在控制器用 email 方法发送邮件 //用126的smtp 发送,示例邮件为 myemail@126.com 密码为 password public function email() { ... 
- 一分钟搭建Webpack+react+es6框架
			最近react刷屏的厉害,而随着它一起走进我们视野的还有webpack,webpack只是个工具,为什么如此火呢?因为简单好了不废话. 直接进入正题: 打开命令行工具: npm install - ... 
- gulp最佳实践(包含js,css,html预编译,合并,压缩,浏览器自动刷新)
			gulp是基于流的自动化构建工具官方网址:http://www.gulpjs.com.cn/ 一.安装需要的模块 1.新建package.json,输入下面的内容 { "name" ... 
- XStream简单使用01——xml和Ojbect互转
			package org.zhb.test; /** * author : zhb * data : 2014-2-14 * use packages: * xmlpull-1.1.3.1.jar * ... 
- 【WPF】布局控件总结
			<Canvas>:画布,默认不会自动裁减超出内容,即溢出的内容会显示在Canvas外面,这是因为默认 ClipToBounds="False":可设置ClipToBou ... 
- 【转】iOS设计模式之观察者模式
			参考:http://blog.csdn.net/xdrt81y/article/details/24039163 或者 http://blog.jobbole.com/55505/ 
- VS2012 独占编辑 设置
			用VS2008建立的项目就有(禁止其他用户签出和签入) 为什么VS2012的项目就没有了呢??(管理员说他什么都没设置)VS2012: 两个项目同样是用VS2012打开的,而第一个是用VS2008创建 ... 
- 离开ACM了,总结一下
			写这篇博客,一如当初我对着电脑显示器,不知道从哪里下手才是,所以没准写着写着就出现了倒叙插叙补叙等充满语文功底的修辞手法,不过不会有45度的妩媚和忧伤. 像一位程序员所说:今天的努力是为了儿时吹过的牛 ... 
- MVC5框架解析之Controller的创建
			在上一讲中我们介绍了MvcHandler,知道在Handler里面注入两个接口属性分别为IControllerFactory和IController的factory和controller.并且通过IO ... 
- 引用Excel时 未在本地计算机上注册ace.oledb.12.0
			可能由于未安装数据库补丁 下载地址http://download.microsoft.com/download/7/0/3/703ffbcb-dc0c-4e19-b0da-1463960fdcdb/A ... 
