hdu3790解题报告
2013-08-23 21:12
267 查看
这里起点和终点都是确定的,唯一有点小麻烦(也算不上什么麻烦)就是这里的权值有两个,钱和路长,题目要求选择最短路,对于一样长度的路选择钱最少的路....那么我们每次就对路长松弛,对于路长一样的在对钱松弛....(不懂松弛操作的很抱歉
)
)
// AC 840k 109ms #include<cstdio> #include<queue> using namespace std; #define MAX 1001 #define IFN 1<<30-1 struct 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; }
相关文章推荐
- hdu 1003 Max Sum 解题报告
- hdu 5373 - The shortest problem 解题报告
- HDU 1312 Red and Black 解题报告
- 解题报告:HDU_3988 Harry Potter and the Hide Story 大素数分解+勒让德
- (解题报告)HDU1000
- HDU - 1010 Tempter of the Bone 深搜模板题(DFS)解题报告
- Monkey and Banana(HDU 1069)解题报告(DP - 滚动数组)
- 杭电acm1282 hdu-acm-1282回文数猜想解题报告
- HDU 1575解题报告
- 坐标序列hdu 1003 解题报告 ---- Max Sum
- HDU 1083&&POJ 1469解题报告
- hdu 1005解题报告
- HDU 4291解题报告
- HDU 4724 If You Know This,You Must Have NO GF 解题报告
- HDU 1846解题报告
- HDU 1848解题报告
- HDU - 2600 War 解题报告
- 解题报告:HDU_6139 Galaxy at War (阶梯博弈)
- HDU 1280 解题报告 第 K 大
- HDU 4560解题报告