题目1008:最短路径问题
来源:互联网 发布:阿里云服务器端口管理 编辑:程序博客网 时间:2024/05/18 13:28
- 题目描述:
- 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。
- 输入:
- 输入n,m,点的编号是1~n,然后是m行,每行4个数 a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p。最后一行是两个数 s,t;起点s,终点t。n和m为0时输入结束。
(1<n<=1000, 0<m<100000, s != t)
- 输出:
- 输出 一行有两个数, 最短距离及其花费。
- 样例输入:
3 21 2 5 62 3 4 51 30 0
- 样例输出:
9 11
这应该是最最最简单的,最最最标准的Dijkstra,直接上代码喽。
#include<iostream>#include<string>#include<algorithm>#include<cstdio>#include<cstring>#include<cmath>using namespace std;const int L=1<<10;const int inf=1<<30;int Map[L][L];int Consume[L][L];int d[L],c[L];bool vis[L];int n,m,s,t;void dijkstra(){ int Min,Pos; fill(vis,vis+n,false); for(int i=1;i<=n;i++) { d[i]=(s==i) ? 0:inf; c[i]=(s==i) ? 0:inf; } for(int i=1;i<=n;i++) { Min=inf; for(int j=1;j<=n;j++) { if(!vis[j] && d[j]<Min) { Pos=j; Min=d[j]; } } vis[Pos]=true; for(int j=1;j<=n;j++) { if(d[j]>d[Pos]+Map[Pos][j]) d[j]=d[Pos]+Map[Pos][j]; if(c[j]>c[Pos]+Consume[Pos][j]) c[j]=c[Pos]+Consume[Pos][j]; } }}int main(){ while(cin>>n>>m && (n || m)) { fill(&Map[0][0],&Map[L][0],inf); fill(&Consume[0][0],&Consume[L][0],inf); for(int i=0;i<m;i++) { int a,b; cin>>a>>b; cin>>Map[a][b]>>Consume[a][b]; Map[b][a]=Map[a][b];Consume[b][a]=Consume[a][b]; } cin>>s>>t; dijkstra(); cout<<d[t]<<" "<<c[t]<<endl; } return 0;}
0 0
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- Jobdu 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题
- 题目1008:最短路径问题 java实现
- 九度oj 题目1008:最短路径问题
- 九度:题目1008:最短路径问题
- 九度题目1008:最短路径问题
- 强制类型转换
- 面向对象之继承
- Android HttpURLConnection(Get,Post方式)进行网络通信 获取数据和网络图片
- Autodesk 首届编程马拉松 ( Hackathon ) 活动, 6.14~15 上海
- 关于CRecordset::Open(vs2010)
- 题目1008:最短路径问题
- 费用报销模块设计
- android专业技术网站
- ajax 取 JSON 中文乱码
- C/C++ 指针 <一>
- 每日阅读(产品) 汤道QQ与微信
- ClassLoader.getResourceAsStream(String resName)
- Windows 8.1更新变化
- SIP开发环境的搭建