题解报告:hdu 3790 最短路径问题
Problem Description
Input
(1<n<=1000, 0<m<100000, s != t)
Output
Sample Input
Sample Output
- #include<bits/stdc++.h>
- using namespace std;
- const int INF = 0x3f3f3f3f;
- const int MAXN = ;
- int n,m,a,b,d,p,s,t,dis[MAXN],cis[MAXN],cost[MAXN][MAXN],G[MAXN][MAXN];//dis数组记录当前节点离起点的最短路径,cis数组记录当前节点离起点的最小费用,cost数组和G数组分别记录费用和节点之间的关系
- bool vis[MAXN];
- void Dijkstra(){
- for(int i=;i<=n;++i){//先默认初始化dis和cis为起点到各节点的最短路径和最小费用
- dis[i]=G[s][i];
- cis[i]=cost[s][i];
- }
- dis[s]=cis[s]=;vis[s]=true;//到自己的距离为0,且0花费
- for(int i=;i<n;++i){ //剩下遍历n-1个节点
- int k=-; //先标记为-1
- for(int j=;j<=n;++j)//查找dis中的最小权值
- if(!vis[j] && (k==- ||dis[j]<dis[k]))k=j;//找到最小权值的下标
- if(k==-)break; //说明已经全部归纳了,直接退出当前循环,否则才可以进行下面的松弛操作
- vis[k]=true; //该点已经归纳最短路径的集合
- for(int j=;j<=n;++j){//更新起点到每个节点的最短路径
- if(!vis[j]){ //如果还没有归纳进去
- if(dis[j]>dis[k]+G[k][j]){
- cis[j]=cis[k]+cost[k][j];
- dis[j]=dis[k]+G[k][j];
- }
- else if(dis[j]==dis[k]+G[k][j] && cis[j]>cis[k]+cost[k][j]) //如果当前多条最短路径,则取两者中较小费用
- cis[j]=cis[k]+cost[k][j];
- }
- }
- }
- }
- int main()
- {
- while(~scanf("%d %d",&n,&m) && (m+n)){
- for(int i=;i<=n;++i){
- for(int j=;j<=n;++j)
- if(i==j)G[i][j]=cost[i][j]=;//到自身的距离和费用都为0
- else G[i][j]=cost[i][j]=INF;//其余初始化为INF
- }
- memset(vis,false,sizeof(vis));
- for(int i=;i<=m;++i){
- scanf("%d %d %d %d",&a,&b,&d,&p);
- if(G[a][b]>d){//预处理,考虑到重边的情况
- G[a][b]=G[b][a]=d;
- cost[a][b]=cost[b][a]=p;
- }
- else if(G[a][b]==d && cost[a][b]>p)//如果a到b的距离等于原来的话,取最小费用
- cost[a][b]=cost[b][a]=p;
- }
- scanf("%d %d",&s,&t);
- Dijkstra();
- printf("%d %d\n",dis[t],cis[t]);
- }
- return ;
- }
AC代码二(优先队列默认最大堆实现Dijkstra迪杰斯特拉算法):
- #include<bits/stdc++.h>
- using namespace std;
- const int INF = 0x3f3f3f3f;
- const int MAXN = ;
- int n,m,a,b,d,p,s,t,dis[MAXN],cis[MAXN],cost[MAXN][MAXN],G[MAXN][MAXN];//dis数组记录当前节点离起点的最短路径,cis数组记录当前节点离起点的最小费用,cost数组和G数组分别记录费用和节点之间的关系
- void Dijkstra(){
- priority_queue< pair<int,int> > que;//最大堆优先队列
- dis[s]=cis[s]=;//到自己的距离为0,且0花费
- que.push(make_pair(-dis[s],s));//加上负号实现最大堆,便于取出最短路径
- while(!que.empty()){
- int k=que.top().second;//每次取出队首元素即最短路径
- que.pop();//弹出队首元素
- for(int i=;i<=n;++i){ //更新邻边权值最小的邻接点
- if(dis[i]>dis[k]+G[k][i]){
- cis[i]=cis[k]+cost[k][i];
- dis[i]=dis[k]+G[k][i];
- que.push(make_pair(-dis[i],i)); //如果有最小权值的邻接点,加入队列中去,记得加负号,因为这是最大堆
- }
- else if(dis[i]==dis[k]+G[k][i] && cis[i]>cis[k]+cost[k][i]) //如果当前多条最短路径,则取两者中较小费用
- cis[i]=cis[k]+cost[k][i];
- }
- }
- }
- int main()
- {
- while(~scanf("%d %d",&n,&m) && (m+n)){
- for(int i=;i<=n;++i)
- dis[i]=cis[i]=INF;//全部初始化为INF无穷大
- for(int i=;i<=n;++i){
- for(int j=;j<=n;++j)
- if(i==j)G[i][j]=cost[i][j]=;//到自身的距离和费用都为0
- else G[i][j]=cost[i][j]=INF;//其余初始化为INF
- }
- for(int i=;i<=m;++i){
- scanf("%d %d %d %d",&a,&b,&d,&p);
- if(G[a][b]>d){//预处理,考虑到重边的情况
- G[a][b]=G[b][a]=d;
- cost[a][b]=cost[b][a]=p;
- }
- else if(G[a][b]==d && cost[a][b]>p)//如果a到b的距离等于原来的话,取最小费用
- cost[a][b]=cost[b][a]=p;
- }
- scanf("%d %d",&s,&t);
- Dijkstra();
- printf("%d %d\n",dis[t],cis[t]);
- }
- return ;
- }
题解报告:hdu 3790 最短路径问题的更多相关文章
- ACM: HDU 3790 最短路径问题-Dijkstra算法
HDU 3790 最短路径问题 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Des ...
- HDU - 3790 最短路径问题 (dijkstra算法)
HDU - 3790 最短路径问题 Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费 ...
- HDU 3790最短路径问题 [最短路最小花费]
题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=3790] 最短路径问题 Time Limit: 2000/1000 MS (Java/Others) ...
- hdu 3790 最短路径问题(双重权值,dijkstra算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 题目大意:题意明了,输出最短路径及其花费. 需要注意的几点:(1)当最短路径相同时,输出最小花费 ...
- hdu 3790 最短路径问题(两个限制条件的最短路)
http://acm.hdu.edu.cn/showproblem.php?pid=3790 有两个条件:距离和花费.首先要求距离最短,距离相等的条件下花费最小. dijkstra,仅仅是在推断条件时 ...
- HDU 3790 最短路径问题 (最短路)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 简单的最短路问题,这题听说有重边.我用spfa和dijkstra写了一遍,没判重边,速度都差不多 ...
- #HDU 3790 最短路径问题 【Dijkstra入门题】
题目: 最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdu 3790 最短路径问题(迪杰斯特拉)
最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- hdu 3790 最短路径dijkstra(多重权值)
最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
随机推荐
- python之cookbook-day02
第一章:数据结构和算法 1.2 解压可迭代对象赋值给多个变量 问题: 如果一个可迭代对象的元素个数超过变量个数时,会抛出一个 ValueError .那么 怎样才能从这个可迭代对象中解压出 N 个元素 ...
- 【模板】大数乘法(51nod 1027)
#include<cstdio> #include<cstring> #include<algorithm> #define LL long long #defin ...
- FZU 1492 地震预测(模拟链表的应用)(Java实现)
FZU 1492 地震预测(模拟链表的应用)(Java实现) 怀特先生是一名研究地震的科学家,最近他发现如果知道某一段时间内的地壳震动能量采样的最小波动值之和,可以有效地预测大地震的发生. 假设已知一 ...
- Trees on the level (二叉链表树)
紫书:P150 uva122 Background Trees are fundamental in many branches of computer science. Current state- ...
- hdu 1867 kmp匹配
#include<stdio.h> #include<string.h> #define N 100100 void getnext(int next[],char s[]) ...
- Spring-data-jpa 笔记(二) Repository 详解
基础的 Repository 提供了最基本的数据访问功能,其几个子接口则扩展了一些功能.它们的继承关系如下: Repository: 是 spring Data 的一个核心接口,它不提供任何方法,开发 ...
- url处理函数
function UrlOption(url) { this.url = url || ''; this.init(); this.change = function (url) { this.url ...
- 非常适合新手的jq/zepto源码分析01
(function(global, factory) { // 查看这里是不是定义成模块,如果定义模块就返回 一个模块 if (typeof define === 'function' &&a ...
- UVa 10315 - Poker Hands
题目:两个人手里各有五张牌,比較两牌型大小. 比較规则例如以下:(按优先级排序,优先级同样按以下内部规则比較) 1.straight-flush:同花顺,牌面连续,花色同样,按最大的值比較. 2.fo ...
- jq 地区(省市县区)联动菜单
<pre name="code" class="html"><pre name="code" class="ph ...