题目链接

题意 : 中文题不详述。

思路 :无论是SPFA还是Dijkstra都在更新最短路的那个地方直接将花费更新了就行,还有别忘了判重边,话说因为忘了判重边WA了一次。

 //
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
const int INF = << ; using namespace std; int n, m,s,t;
int cost[][] ,mapp[][];
int dist[],cost1[] ;
int vis[] ; void spfa(int src)
{
queue<int> Q ;
memset(vis,,sizeof(vis)) ;
for(int i = ; i <= n ; i++)
{
dist[i] = INF ;
cost1[i] = INF ;
}
dist[src] = ;
vis[src] = ;
cost1[src] = ;
Q.push(src) ;
while(!Q.empty())
{
int u = Q.front() ;
Q.pop() ;
vis[u] = ;
for(int i = ; i <= n ; i++)
{ if(dist[i] > dist[u] + mapp[u][i])
{
dist[i] = dist[u] + mapp[u][i] ;
cost1[i] = cost1[u] + cost[u][i] ;
if(!vis[i])
{
vis[i] = ;
Q.push(i) ;
}
}
else if(dist[i] == dist[u]+mapp[u][i])
{
if(cost1[i] > cost1[u] + cost[u][i])
{
cost1[i]=cost1[u] + cost[u][i];
if(!vis[i])
{
vis[i] = ;
Q.push(i) ;
}
} }
}
}
}
void Init()
{
for(int i = ; i <= n ; i++)
for(int j = ; j <= n ; j++)
{
if(i == j) mapp[i][j] = cost[i][j] = ;
else mapp[i][j] = cost[i][j] = INF ;
}
}
int main()
{
//
while(cin >> n >> m)
{
if(n == && m == ) break ;
int a, b , d , p ;
Init() ;
for(int i = ; i < m ; i++)
{
cin >> a >> b >> d >> p ;
if(mapp[a][b] > d)
{
mapp[a][b] = mapp[b][a] = d ;
cost[a][b] = cost[b][a] = p ;
}
else if(mapp[a][b] == d&&cost[a][b] > p)
cost[a][b] = cost[b][a] = p ;
}
cin >> s >> t ;
spfa(s) ;
printf("%d %d\n",dist[t],cost1[t]) ;
}
return ;
}

会神的Dijkstra

 #include <cstdio>
#include <cstring>
#include <algorithm>
#define maxn 1001
using namespace std;
const int inf=<<; int g[maxn][maxn];
int cost[maxn][maxn];
int n,m,a,b,d,p,s,e;
bool vis[maxn];
int dis[maxn],c[maxn]; void inti()
{
for(int i=; i<=n; i++)
{
for(int j=; j<=n; j++)
{
if(i==j)
{
g[i][j]=;
cost[i][j]=;
}
else
{
g[i][j]=inf;
cost[i][j]=inf;
}
}
}
} void dijkstra(int str)
{
memset(vis,false,sizeof(vis));
for(int i=; i<=n; i++)
{
dis[i]=g[str][i];
c[i]=cost[str][i];
}
dis[str]=;
c[str]=; vis[str]=true;
for(int i=; i<n; i++)
{
int m=inf,x;
for(int y=; y<=n; y++) if(!vis[y]&&dis[y]<m) m=dis[x=y];
vis[x]=true;
for(int y=; y<=n; y++)
{
if(!vis[y]&&g[x][y]!=inf)
{
if(dis[y]>dis[x]+g[x][y])
{
dis[y]=dis[x]+g[x][y];
c[y]=c[x]+cost[x][y];
}
else if(dis[y]==dis[x]+g[x][y])
{
if(c[y]>c[x]+cost[x][y])
c[y]=c[x]+cost[x][y];
}
}
}
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n==&&m==) break;
inti();
for(int i=; i<m; i++)
{
scanf("%d%d%d%d",&a,&b,&d,&p);
if(d<g[a][b])
{
g[a][b]=g[b][a]=d;
cost[a][b]=cost[b][a]=p;
} }
scanf("%d%d",&s,&e);
dijkstra(s);
printf("%d %d\n",dis[e],c[e]);
}
return ;
}

HDU 3790 最短路径问题(SPFA || Dijkstra )的更多相关文章

  1. HDU - 3790 最短路径问题 (dijkstra算法)

    HDU - 3790 最短路径问题 Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费 ...

  2. #HDU 3790 最短路径问题 【Dijkstra入门题】

    题目: 最短路径问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  3. HDU 3790 最短路径问题【Dijkstra】

    题意:给出n个点,m条边,每条边的长度d和花费p,给出起点和终点的最短距离和花费,求最短距离,如果有多个最短距离,输出花费最少的 在用dijkstra求最短距离的时候,再用一个f[]数组保存下最少花费 ...

  4. HDU 3790 最短路径问题 (SPFA)

    转载请注明出处:http://blog.csdn.net/a1dark 分析:比一般最短路多了一个花费.多加一个判断即可.用的SPFA.这道题让我搞清楚了以前定义INF为啥爆的问题.受益颇多. #in ...

  5. ACM: HDU 3790 最短路径问题-Dijkstra算法

    HDU 3790 最短路径问题 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Des ...

  6. hdu 3790 最短路径问题(双重权值,dijkstra算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 题目大意:题意明了,输出最短路径及其花费. 需要注意的几点:(1)当最短路径相同时,输出最小花费 ...

  7. hdu 3790 最短路径dijkstra(多重权值)

    最短路径问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  8. HDU 3790 最短路径问题 (最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 简单的最短路问题,这题听说有重边.我用spfa和dijkstra写了一遍,没判重边,速度都差不多 ...

  9. hdu 3790 最短路径问题(两个限制条件的最短路)

    http://acm.hdu.edu.cn/showproblem.php?pid=3790 有两个条件:距离和花费.首先要求距离最短,距离相等的条件下花费最小. dijkstra,仅仅是在推断条件时 ...

随机推荐

  1. 在 Ubuntu 13.10 中搭建Java开发环境 - 懒人版

    本文记录我在Ubuntu 13.10中搭建Java开发环境. 本文环境: Ubuntu 13.10 x64运行在Win7下的VMware Workstation 10中. 1. 安装JDK与JRE s ...

  2. linux调整分区大小

    查看一下当前分区情况 1 2 3 4 5 6 7 8 [root@localhost ~]# df -h Filesystem            Size  Used Avail Use% Mou ...

  3. 邻接矩阵实现Dijkstra算法以及BFS与DFS算法

    //============================================================================ // Name : MatrixUDG.c ...

  4. html表格属性

    一.在表格中插入文字及图片 1.把图片及文字分开到不同的[tr]标签表格内. <html> <body> <table border="1" widt ...

  5. Android -- 获取摄像头帧数据解码

    由于Android下摄像头预览数据只能  ImageFormat.NV21 格式的,所以解码时要经过一翻周折. Camera mCamera = Camera.open(); Camera.Param ...

  6. Oracle Client Language Problem

    If you execute SP in the Oracle client and got the error like this: oracle.xdo.XDOException:   oracl ...

  7. 第七周技术博客发表 web网页开发

    a<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org ...

  8. Beta版软件说明书

    软件使用说明书 一.    软件概述 本软件面向广大简易图片使用者,旨在为用户提供简单方便的不对其他软件产生依赖的截图软件,可以脱机使用. 二.    运行环境 个人电脑,Windows7操作系统,. ...

  9. hibernate--OneToOne

    一对一(one to one) 单向关联映射 两个对象是一对一的的关系. 有两种策略可以实现一对一的关联映射 l  主键关联:即让两个对象具有相同的主键值,以表明他们之间的一对一的对应关系;数据库表不 ...

  10. VS2012配置Lua环境

    1.VS2012配置BabeLua插件 2.VS2012配置Lua 1.VS2012配置BabeLua插件 BabeLua插件简介: 安装方法: 关闭VS2012后直接安装BabeLua插件. 下载地 ...