背景

在很久很久以前,有一个动物村庄,那里是猪的乐园(_),村民们勤劳、勇敢、善良、团结……

不过有一天,最小的小小猪生病了,而这种病是极其罕见的,因此大家都没有储存这种药物。所以晴天小猪自告奋勇,要去采取这种药草。于是,晴天小猪的传奇故事便由此展开……

描述

这一天,他来到了一座深山的山脚下,因为只有这座深山中的一位隐者才知道这种药草的所在。但是上山的路错综复杂,由于小小猪的病情,晴天小猪想找一条需时最少的路到达山顶,但现在它一头雾水,所以向你求助。

山用一个三角形表示,从山顶依次向下有1段、2段、3段等山路,每一段用一个数字T(1<=T<=100)表示,代表晴天小猪在这一段山路上需要爬的时间,每一次它都可以朝左、右、左上、右上四个方向走。山是环形的。(注意:在任意一层的第一段也可以走到本层的最后一段或上一层的最后一段)。

晴天小猪从山的左下角出发,目的地为山顶,即隐者的小屋。

★★★本题为vijos早年陈题,描述晦涩,现重新描述题面如下★★★

有一个数字三角形,共nn行,依次编号为第一行,第二行至第nn行。其中第ii行有ii个数字,位置依次记为(i,1),(i,2)(i,1),(i,2)到(i,i)(i,i)。

现在从第nn层的第一个位置出发(即(n,1)(n,1)),每一步移到相邻的,且行编号小于或等于当前行编号的一个位置中,直到(1,1)(1,1)结束,在不重复经过任何位置的情形下,路过的所有位置(包括端点)的对应数字之和最小。

下面详细定义相邻关系。

同一层内连续的两个位置相邻,特别的有每一层第一个位置与最后一个位置相邻。

对于位置(i,j)(i,j),它与(i-1,j-1)(i−1,j−1)以及(i-1,j)(i−1,j)相邻,特别的(i,1)(i,1)与(i-1,i-1)(i−1,i−1)相邻,且(i,i)(i,i)与(i-1,1)(i−1,1)相邻。

格式

输入格式

第一行有一个数n(2<=n<=1000),表示山的高度。

从第二行至第n+1行,第i+1行有i个数,每个数表示晴天小猪在这一段山路上需要爬的时间。

输出格式

一个数,即晴天小猪所需要的最短时间。

样例1

样例输入1

5

1

2 3

4 5 6

10 1 7 8

1 1 4 5 6

样例输出1

10

题解

这道题目可以看成一道求单源单汇最短路的问题。

我们以左下角的点为起点,最上面的点为终点,对于除终点以外的每个点,我们连接其左、右、左上、上的四个点(特殊规则的点得按特殊规则来),然后按照SPFA算法,开队列来求最短路。

代码:

#include <iostream>
#include <queue>
using namespace std;
struct node
{
int x, y;
};
queue<node> que;
int n, a[1010][1010], f[1010][1010];
bool inMap(int x, int y)
{
return x >= 0 && x < n && y >= 0 && y <= x;
}
void bfs()
{
for (int i = 0; i < n; i ++)
for (int j = 0; j < n; j ++)
f[i][j] = -1;
f[n-1][0] = a[n-1][0];
node u;
u.x = n-1;
u.y = 0;
que.push(u);
while(!que.empty())
{
node u = que.front();
que.pop();
int ux = u.x, uy = u.y;
if (u.x == 0 && u.y == 0)
{
continue;
}
node v;
// left
if (u.y > 0)
{
v.x = u.x;
v.y = u.y - 1;
}
else
{
v.x = u.x;
v.y = u.x;
}
if (inMap(v.x, v.y) && (f[v.x][v.y] == -1 || f[v.x][v.y] > f[u.x][u.y] + a[v.x][v.y]))
{
f[v.x][v.y] = f[u.x][u.y] + a[v.x][v.y];
que.push(v);
}
// right
if (u.x == u.y)
{
v.x = u.x;
v.y = 0;
}
else
{
v.x = u.x;
v.y = u.y + 1;
}
if (inMap(v.x, v.y) && (f[v.x][v.y] == -1 || f[v.x][v.y] > f[u.x][u.y] + a[v.x][v.y]))
{
f[v.x][v.y] = f[u.x][u.y] + a[v.x][v.y];
que.push(v);
}
// up
if (u.x == u.y)
{
v.x = u.x - 1;
v.y = 0;
}
else
{
v.x = u.x - 1;
v.y = u.y;
}
if (inMap(v.x, v.y) && (f[v.x][v.y] == -1 || f[v.x][v.y] > f[u.x][u.y] + a[v.x][v.y]))
{
f[v.x][v.y] = f[u.x][u.y] + a[v.x][v.y];
que.push(v);
}
// up-left
if (u.y == 0)
{
v.x = u.x - 1;
v.y = v.x;
}
else
{
v.x = u.x - 1;
v.y = u.y - 1;
}
if (inMap(v.x, v.y) && (f[v.x][v.y] == -1 || f[v.x][v.y] > f[u.x][u.y] + a[v.x][v.y]))
{
f[v.x][v.y] = f[u.x][u.y] + a[v.x][v.y];
que.push(v);
}
}
cout << f[0][0] << endl;
} int main()
{
cin >> n;
for (int i = 0; i < n; i ++)
for (int j = 0; j <= i; j ++)
cin >> a[i][j];
bfs();
return 0;
}

Vijos 1006 晴天小猪历险记之Hill 单源单汇最短路的更多相关文章

  1. vijos 1006 晴天小猪历险记之Hill——数字三角形的终极变化

    题目链接:https://vijos.org/p/1006 数字三角形原题看这里:http://www.cnblogs.com/huashanqingzhu/p/7326837.html 背景 在很久 ...

  2. 【vijos】1006 晴天小猪历险记之Hill(dijkstra)

    https://vijos.org/p/1006 连边后跑点权的最短路 注意连边的时候左端点可以连到下一行的右端点,右端点可以连到下一行的左端点 #include <cstdio> #in ...

  3. vijosP1006 晴天小猪历险记之Hill

    vijosP1006 晴天小猪历险记之Hill 链接:https://vijos.org/p/1006 [思路] 图上DP. 这个题的递推顺序是关键.先从上一行得到最小值,然后从本行比较最小值,注意本 ...

  4. Vijos1006P1006晴天小猪历险记之Hill[最短路]

    P1006晴天小猪历险记之Hill Accepted 标签:晴天小猪历险记[显示标签]     背景 在很久很久以前,有一个动物村庄,那里是猪的乐园(^_^),村民们勤劳.勇敢.善良.团结……不过有一 ...

  5. hdoj 2066 一个人的旅行 【多源多汇最短路】

    题目:hdoj 2066 一个人的旅行 方法:缩点 + 最短路 分析:看了大神的一篇博客,讲冗余压缩的,然后就想找一个多源最短路练练手. 这个题目就是典型的多源多汇最短路 方法:把全部的源点压缩成一个 ...

  6. POJ - 3268 Silver Cow Party SPFA+SLF优化 单源起点终点最短路

    Silver Cow Party One cow from each of N farms (1 ≤ N ≤ 1000) conveniently numbered 1..N is going to ...

  7. 晴天小猪历险记之Hill(Dijkstra优先队列优化)

    描述 这一天,他来到了一座深山的山脚下,因为只有这座深山中的一位隐者才知道这种药草的所在.但是上山的路错综复杂,由于小小猪的病情,晴天小猪想找一条需时最少的路到达山顶,但现在它一头雾水,所以向你求助. ...

  8. 通信网Project之——单源单宿最短路问题

    最主要的Vertex类: #ifndef VERTEX_H #define VERTEX_H #include <climits> #include <cstddef> #de ...

  9. 湖南省第十二届大学生计算机程序设计竞赛 F 地铁 多源多汇最短路

    1808: 地铁 Description Bobo 居住在大城市 ICPCCamp. ICPCCamp 有 n 个地铁站,用 1,2,…,n 编号. m 段双向的地铁线路连接 n 个地铁站,其中第 i ...

随机推荐

  1. 面试(3)-java-se-java中的匿名内部类总结

    java中的匿名内部类总结 匿名内部类也就是没有名字的内部类 正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写 但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口 实例1 ...

  2. Smart.coder每日站立会议08

    站立会议内容: 完善小程序的查找功能,打算考虑一下信息自动输入分类的功能. 1.站立会议照片: 2.任务展板 3.燃尽图

  3. ArrayList构造方法源码分析

    首先看一下无参的构造方法: private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {}; transient Object ...

  4. 关于laravel5.2仓库的建立,以及简单调用

    laravel个人比较喜欢,就是控制器里面逻辑代码的分离,这样结构很清晰,有利于后期的维护,现在就把平时工作中运用的仓库模式,分享一下,望指正. *************************** ...

  5. countDownLatch和cyclicBarrier

    < Effecit In Java >说过,从java 1.5发现版本开始, 就不建议使用wait和notify,它们使用比较困难,可以使用更高级并发工具来替代. 图一所说的同步器是指那些 ...

  6. OpenCv关于灰度积分图的SSE代码学习和改进。

    最近一直沉迷于SSE方面的优化,实在找不到想学习的参考资料了,就拿个笔记本放在腿上翻翻OpenCv的源代码,无意中看到了OpenCv中关于积分图的代码,仔细研习了一番,觉得OpenCv对SSE的灵活运 ...

  7. Markdown常用语法对应

    这是一遍备忘录,当忘记Markdown的语法的时候,就到这里来参照. 第一部分是markdown的语法,紧接着就是该语法的效果. 代码语法高亮 ```javascript function synta ...

  8. 解决其他浏览器没有propertychange事件

    监听实现: /** * Listener.js * 此类用于解决非ie下,通过js改变input的值时, * 无法触发其事件的问题(如:onpropertychange, oninput, oncha ...

  9. java面试笔试大汇总

    java面试笔试题大汇总5 JAVA相关基础知识 1.面向对象的特征有哪些方面 1.抽象:2.继承:3.封装:4. 多态性: 2.String是最基本的数据类型吗? 基本数据类型包括byte.int. ...

  10. 抓包工具 - Fiddler(详细介绍)

    Fiddler的详细介绍 一.Fiddler与其他抓包工具的区别 1.Firebug虽然可以抓包,但是对于分析http请求的详细信息,不够强大.模拟http请求的功能也不够,且firebug常常是需要 ...