【HDOJ】1688 Sightseeing
Dijkstra求解次短路径,使用cnt和dis数组记录最小、次小的个数和长度。重写更新操作。
/* 1688 */
#include <iostream>
#include <string>
#include <map>
#include <queue>
#include <set>
#include <vector>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <climits>
#include <cctype>
using namespace std; #define MAXN 1005
#define INF 0x3f3f3f3f typedef struct Edge_t {
int v, w;
Edge_t() {}
Edge_t(int u, int ww) {
v = u; w = ww;
}
} Edge_t; vector<Edge_t> vc[MAXN];
bool visit[MAXN][];
int dis[MAXN][];
int cnt[MAXN][];
int n, m; void init() {
int i; for (i=; i<=n; ++i)
vc[i].clear();
memset(cnt, , sizeof(cnt));
} int dijkstra(int s, int f) {
int i, j, k, tmp, r;
int u, v, w, mmin;
int ret = ;
Edge_t e; memset(visit, false, sizeof(visit));
memset(dis, 0x3f, sizeof(dis));
dis[s][] = ;
cnt[s][] = ; for (r=; r<n*; ++r) {
mmin = INF;
u = -;
for (j=; j<=n; ++j) {
if (!visit[j][] && dis[j][]<mmin) {
mmin = dis[j][];
u = j;
k = ;
} else if (!visit[j][] && dis[j][]<mmin) {
mmin = dis[j][];
u = j;
k = ;
}
}
if (u == -)
break;
visit[u][k] = true;
for (i=; i<vc[u].size(); ++i) {
e = vc[u][i];
v = e.v;
w = e.w;
tmp = w + dis[u][k];
if (tmp < dis[v][]) {
dis[v][] = dis[v][];
cnt[v][] = cnt[v][];
dis[v][] = tmp;
cnt[v][] = cnt[u][k];
} else if (tmp == dis[v][]) {
cnt[v][] += cnt[u][k];
} else if (tmp < dis[v][]) {
dis[v][] = tmp;
cnt[v][] = cnt[u][k];
} else if (tmp == dis[v][]) {
cnt[v][] += cnt[u][k];
}
}
} ret += cnt[f][];
if (dis[f][]+ == dis[f][])
ret += cnt[f][];
return ret;
} int main() {
int t;
int i, j, k;
Edge_t e; #ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif scanf("%d", &t);
while (t--) {
scanf("%d %d", &n, &m);
init();
while (m--) {
scanf("%d %d %d", &i, &e.v, &e.w);
vc[i].push_back(e);
}
scanf("%d %d", &i, &j);
k = dijkstra(i, j);
printf("%d\n", k);
} return ;
}
【HDOJ】1688 Sightseeing的更多相关文章
- 【HDOJ】4729 An Easy Problem for Elfness
其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...
- 【HDOJ】【3506】Monkey Party
DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...
- 【HDOJ】【3516】Tree Construction
DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...
- 【HDOJ】【3480】Division
DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...
- 【HDOJ】【2829】Lawrence
DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...
- 【HDOJ】【3415】Max Sum of Max-K-sub-sequence
DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...
- 【HDOJ】【3530】Subsequence
DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...
- 【HDOJ】【3068】最长回文
Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...
- 【HDOJ】【1512】Monkey King
数据结构/可并堆 啊……换换脑子就看了看数据结构……看了一下左偏树和斜堆,鉴于左偏树不像斜堆可能退化就写了个左偏树. 左偏树介绍:http://www.cnblogs.com/crazyac/arti ...
随机推荐
- Task类(任务)
任务表示应完成的某个单元的工作.这个单元的工作可以在单独的线程中运行,也可以以同步方式启动一个任务,这需要等待主调用线程.使用任务不仅可以获得一个抽象层,还可以对底层线程进行很多控制. 1.启动任务 ...
- SQL_server 的基本操作
1.---------------数据库基本操作 主键 : 1.不重复 2.不为NULL外键 1.取消重复行(消除完全一样的行,保留一行)select distinct cloumname1,clou ...
- GPS定位,经纬度附近地点查询–C#实现方法
目前的工作是需要手机查找附近N米以内的商户,功能如下图 数据库中记录了商家在百度标注的经纬度(如:116.412007, 39.947545), 最初想法 以圆心点为中心点,对半径做循环,半径每增加 ...
- Android - NullPointerException
Android中的空指针,感觉出现率,比普通的java出现的概率多得多,今天我无意中发现的NullPointerException,还是想记录下来. 我们知道, 我们的控件一般定义在layout.xm ...
- C#调用ActiveX控件
背景:最近项目中需要用到ActiveX控件,项目是在.Net平台下开发的.因此就直接在项目中添加了对ActiveX控件的引用,添加引用成功.在代码中实例化类的实例也没有问题,但在调用其方法或属性时总是 ...
- 前端开发bower包管理器
Bower 是 twitter 推出的一款包管理工具,基于nodejs的模块化思想,他可以很好的帮助你帮你解决js的依赖管理,比如jquery angular bootstrap 等等. 可以很方便的 ...
- 逻辑回归:使用SGD(Stochastic Gradient Descent)进行大规模机器学习
Mahout学习算法训练模型 mahout提供了许多分类算法,但许多被设计来处理非常大的数据集,因此可能会有点麻烦.另一方面,有些很容易上手,因为,虽然依然可扩展性,它们具有低开销小的数据集.这样一个 ...
- struts2 package元素
<package../>元素 name 必选 包名 extends 可选 继承 namespace ...
- Discuz论坛下载与安装
Part1 Discuz下载 百度“discuz下载” 2. 找到下图这里 3. 选择你需要的版本,这里我选了X3.1版 4. 选择UTF-8简体下载 这是我下载好的文件 Part2 Discuz安装 ...
- Object之魔术函数__toString() 直接输出对象引用时自动调用
__toString()是快速获取对象的字符串信息的便捷方式 在直接输出对象引用时自动调用的方法. __toString()的作用 当我们调试程序时,需要知道是否得出正确的数据.比如打印一个对象时,看 ...