hdu3790最短路径问题
来源:互联网 发布:有益网络怎么样 编辑:程序博客网 时间:2024/05/22 02:03
这是一个最短路径的裸题,我们在边结构体中 添加成员路径和花费,然后在松弛操作的时候用这两个来松弛就OK
// AC 840k 109ms#include<cstdio>#include<queue>using namespace std;#define MAX 1001#define IFN 1<<30-1struct node{int to,len,cost,next;}edge[MAX*100*2];int head[MAX],tol;int n,m,st,end;void init(){int i;for(i=1;i<=n;i++) head[i]=-1;tol=0;int a,b,l,c;for(i=0;i<m;i++){scanf("%d%d%d%d",&a,&b,&l,&c);edge[tol].to=b,edge[tol].len=l,edge[tol].cost=c;edge[tol].next=head[a];head[a]=tol++;edge[tol].to=a,edge[tol].len=l,edge[tol].cost=c;edge[tol].next=head[b];head[b]=tol++;}scanf("%d%d",&st,&end);}int d[MAX],cost[MAX];bool flag[MAX];int main(){while(scanf("%d%d",&n,&m),n+m){init();int i;for(i=1;i<=n;i++) d[i]=IFN,cost[i]=IFN,flag[i]=false;d[st]=0,cost[st]=0;queue<int>q;q.push(st);while(!q.empty()){int u=q.front();q.pop();flag[u]=false;for(int j=head[u];j!=-1;j=edge[j].next){int v=edge[j].to,l=edge[j].len,c=edge[j].cost;if(d[v]>d[u]+l || (d[v]==d[u]+l) && cost[v]>cost[u]+c){d[v]=d[u]+l;cost[v]=cost[u]+c;if(!flag[v])q.push(v),flag[v]=true;}}}printf("%d %d\n",d[end],cost[end]);}return 0;}
2 1
- hdu3790 最短路径问题
- hdu3790 最短路径问题
- HDU3790--最短路径问题
- hdu3790 最短路径问题
- hdu3790 最短路径问题
- HDU3790:最短路径问题
- hdu3790 最短路径问题
- hdu3790最短路径问题
- hdu3790 最短路径问题
- hdu3790最短路径问题
- [hdu3790]最短路径问题
- HDU3790-最短路径问题
- hdu3790 最短路径问题
- HDU3790 最短路径问题
- HDU3790 最短路径问题
- HDU3790 最短路径问题
- hdu3790 最短路径问题
- hdu3790最短路径问题
- Linux Shell脚本与Vim常用操作笔记
- 继续xxx定律 hdoj 3784
- iOS 中的NSTimer定时器的作用
- ssl证书笔记
- yaml 4种java支持库的比较
- hdu3790最短路径问题
- 临时链接
- Bootloader - Main system - Recovery的三角关系
- 二叉排序树
- JDK 动态代理 模拟
- mtk note
- 撕裂我的头发
- 二进制、八进制、十六进制
- 上班第一天