裸裸的最短路问题,将while(scanf("%d%d", &N, &M)!=EOF)粗心写为while(scanf("%d%d", &N, &M),我还奇怪怎么一直是超时,OMG.

首先用Dijstra算法,寻找两点间最短路径长度,算法复杂度是O(n^2).

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
using namespace std;
#define MAX_SIZE 202
#define MAX_NUMBER INT_MAX/2
int dis[MAX_SIZE];
bool visit[MAX_SIZE];
int G[MAX_SIZE][MAX_SIZE];
int N, M;
void Dijstra(int s,int t);
int main() {
int i, j,k,w,s,t;
while (scanf("%d%d", &N, &M)!=EOF) {
for (i = 0; i < N; i++) {
G[i][i] = 0;
for (j = i + 1; j < N; j++)
G[i][j] = G[j][i] = MAX_NUMBER;
}
for (k = 0; k < M; k++) {
scanf("%d%d%d", &i, &j, &w);
if(w<G[i][j])
G[i][j] = G[j][i] = w;
}
scanf("%d%d", &s, &t);
Dijstra(s,t);
if (dis[t] != MAX_NUMBER)
printf("%d\n", dis[t]);
else
printf("-1\n");
}
return 0;
}
void Dijstra(int s,int t) {
int i, j, k,pos,lmin;
for (i = 0; i < N; i++) {
visit[i] = 0;
dis[i] = MAX_NUMBER;
}
j = s;
dis[j] = 0;
visit[j] = 1;
for (i = 0; i < N; i++) {
for (k = 0; k <N; k++) {
if (!visit[k] && dis[k]>dis[j] + G[k][j])
dis[k] = dis[j] + G[k][j];
}
pos =s; lmin = MAX_NUMBER;
for (k =0; k <N; k++) {
if (!visit[k] && lmin > dis[k]) {
pos = k;
lmin = dis[k];
}
}
j = pos;
if (j ==s||j==t)
return;
visit[j] = 1;
}
}

  接着使用Floyd算法也可以解决,时间复杂度是O(n^3),当然在这里是多此一举,不需要求出任意两点间最短距离。

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
using namespace std;
#define MAX_SIZE 202
#define MAX_NUMBER INT_MAX/2
int dis[MAX_SIZE][MAX_SIZE];
int G[MAX_SIZE][MAX_SIZE];
int N, M;
void Floyd();
int main() {
int i, j, k, w, s, t;
while (scanf("%d%d", &N, &M) != EOF) {
for (i = 0; i < N; i++) {
G[i][i] = 0;
for (j = i + 1; j < N; j++)
G[i][j] = G[j][i] = MAX_NUMBER;
}
for (k = 0; k < M; k++) {
scanf("%d%d%d", &i, &j, &w);
if (w<G[i][j])
G[i][j] = G[j][i] = w;
}
scanf("%d%d", &s, &t);
Floyd();
if (dis[s][t] != MAX_NUMBER)
printf("%d\n", dis[s][t]);
else
printf("-1\n");
}
return 0;
}
void Floyd() {
int i, j, k;
for (i = 0; i < N; i++)
for (j = 0; j < N; j++)
dis[i][j] = G[i][j];
for (k = 0; k < N; k++)
for (i = 0; i < N; i++)
for (j = 0; j < N; j++)
if (dis[i][j]>dis[i][k] + dis[k][j])
dis[i][j] = dis[i][k] + dis[k][j];
}

hdu1874最短路的更多相关文章

  1. HDU1874 最短路 SPFA

    最短路 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 24  Solved: 17 [Submit][Status][Web Board] Descr ...

  2. hdu1874 最短路模板题

    之所以做了第二道模板题还要写是因为发现了一些自己的问题 用的是dij 最简单的松弛 需要注意的地方是松弛的时候 判断dis[i]<dis[w]+tance[w][i]时 还要再判断 vis[i] ...

  3. hdu1874 畅通project续 最短路 floyd或dijkstra或spfa

    Problem Description 某省自从实行了非常多年的畅通project计划后.最终修建了非常多路.只是路多了也不好,每次要从一个城镇到还有一个城镇时,都有很多种道路方案能够选择.而某些方案 ...

  4. hdu1874 (spfa 最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 很简单的最短路问题,刚刚学习spfa,其实很简单,思想和一维动态规划差不多,数组d[i]表示起点 ...

  5. 最短路(Bellman)-Hdu1874畅通工程序

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目: 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城 ...

  6. bzoj1001--最大流转最短路

    http://www.lydsy.com/JudgeOnline/problem.php?id=1001 思路:这应该算是经典的最大流求最小割吧.不过题目中n,m<=1000,用最大流会TLE, ...

  7. 【USACO 3.2】Sweet Butter(最短路)

    题意 一个联通图里给定若干个点,求他们到某点距离之和的最小值. 题解 枚举到的某点,然后优先队列优化的dijkstra求最短路,把给定的点到其的最短路加起来,更新最小值.复杂度是\(O(NElogE) ...

  8. Sicily 1031: Campus (最短路)

    这是一道典型的最短路问题,直接用Dijkstra算法便可求解,主要是需要考虑输入的点是不是在已给出的地图中,具体看代码 #include<bits/stdc++.h> #define MA ...

  9. 最短路(Floyd)

    关于最短的先记下了 Floyd算法: 1.比较精简准确的关于Floyd思想的表达:从任意节点A到任意节点B的最短路径不外乎2种可能,1是直接从A到B,2是从A经过若干个节点X到B.所以,我们假设maz ...

随机推荐

  1. php 实现栈与队列

    <?php class queueOp{ /* * 队尾入队 * Return:处理之后队列的元素个数 */ public function tailEnquque($arr,$val){ re ...

  2. redis设置最大内存上限对置换策略的解读

    现在很少服务器还在使用32位的操作系统了,所以服务器的内存可以接近极限2^64的字节.redis配置文件中有限制最大内存的字段maxmemory,当redis的key达到最大值时,redis会有多种策 ...

  3. cookie和session机制区别

    会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...

  4. firewalld的防火墙

    firewalld的介绍与简单应用 CentOS7的默认防火墙是firewalld,在之前使用iptables时,关闭了firewalld服务,现在反过来关闭iptables服务,打开firewall ...

  5. java替换富文本标签等

    (转自:http://www.cnblogs.com/1246447850qqcom/p/5439366.html) package q;import java.util.regex.Matcher; ...

  6. cf 853 D Michael and Charging Stations [dp]

    题面: 传送门 思路: 看到题目,第一思路是贪心,但是我很快就否决掉了(其实分类贪心也可以做) 然后就想,贪心不能解决的状态缺失,是否可以用dp来解决呢? 事实证明是可以的 我们设dp[i][j]表示 ...

  7. 密码 (pasuwado)

    密码 (pasuwado) 题目描述 哪里有压迫,哪里就有反抗. moreD的宠物在法庭的帮助下终于反抗了.作为一只聪明的宠物,他打算把魔法使moreD的魔法书盗去,夺取moreD的魔法能力.但mor ...

  8. GROUP BY子句的查询中显示COUNT()为0的结果

    含有GROUP BY子句的查询中如何显示COUNT()为0的结果 在SQL Server数据库查询中,为了对查询结果进行对比.分析,我们经常会用到GROUP BY子句以及COUNT()函数来对查询结果 ...

  9. 洛谷P1816 忠诚

    P1816 忠诚 569通过 1.5K提交 题目提供者该用户不存在 标签云端 难度普及+/提高 时空限制1s / 128MB 提交  讨论  题解 最新讨论更多讨论 主席树的常数貌似大于线段树… TL ...

  10. 沼泽鳄鱼(bzoj 1898)

    Description 潘塔纳尔沼泽地号称世界上最大的一块湿地,它地位于巴西中部马托格罗索州的南部地区.每当雨季来临,这里碧波荡漾.生机盎然,引来不少游客.为了让游玩更有情趣,人们在池塘的中央建设了几 ...