JZOJ 5793. 【NOIP2008模拟】小S练跑步
5793. 【NOIP2008模拟】小S练跑步
(File IO): input:run.in output:run.out
Description
但不久后,他就开始为在重复的地点练习感到厌烦了,他就打算去B公园跑步。
但是小S由于没有去过B公园,他不知道B公园是否适合练习跑步,又不知道在B公园怎样跑是最优的。所以小S就去B公园进行了一番勘测。
小S在进行了一番勘测后,画出了一张地图,地图每一个位置上都辨识了小S到达该位置后不能往哪一个方位移动。其中有5种表示的符号:“U”代表不能向上移动,“D”代表不能向下移动,“L”代表不能向左移动,“R”代表不能向右移动,如果该位置有障碍物,小S到达那里后无法继续训练,就用“S”来代表。整个公园共有n行m列,小S会从第1行第1列出发,到第n行第m列结束他的练习。
现在小S想要知道,从起点(即第1行第1列)到终点(第n行第m列),途中最少要改变几次方向(即上一次移动的方向和这一次移动的方向不一样)?
注意:小S如在训练途中离开公园(即地图范围),则算是结束训练。
Input
第2~n+1行,每行有m个字符,表示小S的移动方向。
Output
Sample Input
3 3
ULL
LDU
SUD
Sample Output
1 【样例解释】
小S先向右移动移动了2格,再向下移动2格,就到达了终点,这样只用改变一次方向。
Data Constraint
10%的数据是题目的馈赠。
30%的数据,1≤n,m≤10。
50%的数据,1≤n,m≤50。
70%的数据,1≤n,m≤250。
100%的数据,1≤n,m≤500.
其中50%的数据是先构造出路径,再构造地图的。
100%数据是随机构造的。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <string>
#define M 507
using namespace std;
int n, m, map[M][M], dis[M][M][], list[][];
string s;
int dy[] = {, , , -, };
int dx[] = {, -, , , }; void init()
{
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++)
{
cin >> s;
for (int j = ; j < m; j++)
{
if (s[j] == 'U') map[i][j + ] = ;
if (s[j] == 'D') map[i][j + ] = ;
if (s[j] == 'L') map[i][j + ] = ;
if (s[j] == 'R') map[i][j + ] = ;
if (s[j] == 'S') map[i][j + ] = ;
}
}
} bool check(int x, int y, int w, int to)
{
if (map[x][y] == &&(x != n || y != m)) return ;
if (x > n || x < ) return ;
if (y > m || y < ) return ;
if (to >= dis[x][y][w]) return ;
if (to >= dis[x][y][] + ) return ;
dis[x][y][] = min(dis[x][y][], to);
dis[x][y][w] = to;
return ;
} void Bfs()
{
int head = , tail = ;
memset(dis, 0x7f7f7f7f, sizeof(dis));
dis[][][] = ;
dis[][][] = ;
dis[][][] = ;
dis[][][] = ;
for (int i = ; i <= ; i++)
if (map[][] != i)
{
list[++tail][] = ;
list[tail][] = ;
list[tail][] = i;
}
while (head < tail)
{
int u = list[++head][], v = list[head][], now = list[head][], val = list[head][];
for (int i = ; i <= ; i++)
if (map[u][v] != i)
{
int ain_u = u + dx[i], ain_v = v + dy[i];
int W = val;
if (now != i) W++;
if (!check(ain_u, ain_v, i, W)) continue;
list[++tail][] = ain_u;
list[tail][] = ain_v;
list[tail][] = i;
list[tail][] = W;
}
}
int ans = 0x7f7f7f7f;
for (int i = ; i <= ; i++)
ans = min(ans, dis[n][m][i]);
if (ans == 0x7f7f7f7f) printf("No Solution");
else printf("%d", ans);
} int main()
{
freopen("run.in", "r", stdin);
freopen("run.out", "w", stdout);
init();
Bfs();
}
JZOJ 5793. 【NOIP2008模拟】小S练跑步的更多相关文章
- JZOJ 5777. 【NOIP2008模拟】小x玩游戏
5777. [NOIP2008模拟]小x玩游戏 (File IO): input:game.in output:game.out Time Limits: 1000 ms Memory Limits ...
- JZOJ 5776. 【NOIP2008模拟】小x游世界树
5776. [NOIP2008模拟]小x游世界树 (File IO): input:yggdrasil.in output:yggdrasil.out Time Limits: 1500 ms Me ...
- JZOJ 5775. 【NOIP2008模拟】农夫约的假期
5775. [NOIP2008模拟]农夫约的假期 (File IO): input:shuru.in output:shuru.out Time Limits: 1000 ms Memory Lim ...
- JZOJ 5773. 【NOIP2008模拟】简单数学题
5773. [NOIP2008模拟]简单数学题 (File IO): input:math.in output:math.out Time Limits: 1000 ms Memory Limits ...
- JZOJ5776. 【NOIP2008模拟】小x游世界树
题目:[NOIP2008模拟]小x游世界树: 题目的附加题解给的很清楚,这里只给一个代码: #include<iostream> #include<cstdio> #inclu ...
- JZOJ 5809. 【NOIP2008模拟】数羊
5809. [NOIP2008模拟]数羊 (File IO): input:sheep.in output:sheep.out Time Limits: 1000 ms Memory Limits: ...
- JZOJ 5791. 【NOIP2008模拟】阶乘
5791. [NOIP2008模拟]阶乘 (File IO): input:factorial.in output:factorial.out Time Limits: 1000 ms Memory ...
- JZOJ 5771. 【NOIP2008模拟】遨游
5771. [NOIP2008模拟]遨游 (File IO): input:trip.in output:trip.out Time Limits: 2000 ms Memory Limits: 2 ...
- 「SCOI2015」小凸想跑步 解题报告
「SCOI2015」小凸想跑步 最开始以为和多边形的重心有关,后来发现多边形的重心没啥好玩的性质 实际上你把面积小于的不等式列出来,发现是一次的,那么就可以半平面交了 Code: #include & ...
随机推荐
- Tree and Queries CodeForces - 375D 树上莫队
http://codeforces.com/problemset/problem/375/D 树莫队就是把树用dfs序变成线性的数组. (原数组要根据dfs的顺序来变化) 然后和莫队一样的区间询问. ...
- ElasticSearch2.2.0安装(win7)
ElasticSearch2.2.0必须在jdk1.7上才可以启动起来哦. 一.ElasticSearch2.2.0安装 1.下载ElasticSearch2.2.0安装包 https://downl ...
- DataBinding 访问 3
MVVM中的Model 我们可以用任何POJO 作为 data binding 的 Model, 但是直接修改POJO对象,不能直接更新UI android的 dataBinding 模块 给提供了通 ...
- hibernate课程 初探单表映射1-3 hibernate简介
1 hibernate定义: Java领域一项开源的orm框架技术: hibernate对jdbc进行轻量级的封装. hibernate 作为持久层存在.就是通过对象关系映射把项目中的对象持久化到数据 ...
- hibernate课程 初探单表映射1-2 ORM定义
1 什么是ORM? ORM(Object / RelationShip Mapping) 对象/关系映射 面向对象编程(OOP)最终要把对象信息保存在关系性数据库中,要写好多sql语句.这与面向对象编 ...
- 微信小程序开发入门首选
推荐一本书吧,直接上图,微信开发,微信网页开发,微信小程序开发,都用得着. 推荐一本书吧,直接上图,微信开发,微信网页开发,微信小程序开发,都用得着. 推荐一本书吧,直接上图,微信开发,微信网页开发, ...
- lattice diamond fpga 状态机的理解
比如序列检测101,需要三个状态 :so,s1,s2. 思路:(1)s0状态有两种情况0或1,若为0时在自身打圈,是1时进入s1状态. (2)s1状态有两种0或1,若为1自身打圈,因为1可以作为下次检 ...
- 可以让表格变为拖动边界调整列宽度的JS办法
需要引入文件: jquery.resizableColumns.min.js 和 jquery.resizableColumns.css 代码如下: $(".tableclass" ...
- CDQ分治入门
前言 \(CDQ\)分治是一个神奇的算法. 它有着广泛的用途,甚至在某些题目中还能取代\(KD-Tree\).树套树等恶心的数据结构成为正解,而且常数还小得多. 不过它也有一定的缺点,如必须离线操作, ...
- 管理员必备的几个Linux系统监控工具
需要监控Linux服务器系统性能吗?尝试下面这些系统内置或附件的工具吧.大多数Linux发行版本都装备了大量的监控工具.这些工具提供了能用作取得相关信息和系统活动的量度指标.你能使用这些工具发现造成性 ...