首页 > 代码库 > HDU3790最短路径问题
HDU3790最短路径问题
最短路径问题
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 13374 Accepted Submission(s): 4087
Problem Description
给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。
Input
输入n,m,点的编号是1~n,然后是m行,每行4个数 a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p。最后一行是两个数 s,t;起点s,终点。n和m为0时输入结束。
(1<n<=1000, 0<m<100000, s != t)
(1<n<=1000, 0<m<100000, s != t)
Output
输出 一行有两个数, 最短距离及其花费。
Sample Input
3 21 2 5 62 3 4 51 30 0
Sample Output
9 11
Source
#include<iostream>#include<cstdio>#include<cstring>#include<algorithm>#include<queue>using namespace std;const int MX=1<<30;int Road[1100][1100][2],n,fz[1100][2];int s,e;struct node{ int s,l,fee;};void dfs(int &l,int &fee){ node a,b; a.s=s; a.l=0; a.fee=0; l=fee=MX; fz[a.s][0]=0; fz[a.s][1]=1; queue<node>q; q.push(a); while(!q.empty()) { a=q.front(); q.pop(); for(int i=1;i<=n;i++) { b.s=i; b.l=a.l+Road[a.s][i][0]; b.fee=a.fee+Road[a.s][i][1]; if(Road[a.s][i][0]!=MX&& (fz[i][0]>b.l||(fz[i][0]==b.l&&fz[i][1]>b.fee))) { fz[i][0]=b.l; fz[i][1]=b.fee; if(b.s==e&&(l>b.l||(l==b.l&&fee>b.fee))) { l=b.l; fee=b.fee; } q.push(b); } } }}int main(){ int m; while(scanf("%d%d",&n,&m)!=EOF) { int i,j,a,b,c,d; if(n==0&&m==0)break; for(i=0;i<=n;i++) { for(j=0;j<=n;j++) { Road[i][j][0]=MX; Road[i][j][1]=MX; } fz[i][0]=MX; fz[i][1]=MX; }//初始化 for(i=0;i<m;i++) { scanf("%d%d%d%d",&a,&b,&c,&d); if(c<Road[a][b][0]||(c==Road[a][b][0]&&Road[a][b][1]>d)){ Road[a][b][0]=c; Road[b][a][0]=c; Road[a][b][1]=d; Road[b][a][1]=d;} } scanf("%d%d",&s,&e); int l,fee; dfs(l,fee); printf("%d %d\n",l,fee); } return 0;}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。