• 07-图5. 旅游规划(25)


    #include <stdio.h>
    #include <string.h>
    #include <iostream>
    #include <algorithm>
    #include <vector>
    #include <queue>
    #include <stack>
    #include <set>
    #include <map>
    #include <string>
    #include <math.h>
    #include <stdlib.h>
    #include <time.h>
    using namespace std;
    const int N=500+5;
    const int inf=1<<30;
    
    struct node
    {
        int w,t;
    } edge[N][N];
    
    int n,dist[N],path[N],vis[N],worth[N];
    
    void dijkstra(int v0)
    {
        int i,j,k,wmin,tmin,u;
        for(i=0; i<n; i++)
        {
            dist[i]=edge[v0][i].w;
            worth[i]=edge[v0][i].t;
            vis[i]=0;
            if(i!=v0&&edge[v0][i].w<inf) path[i]=v0;
            else path[i]=-1;
        }
        vis[v0]=1;
        dist[v0]=0;
        worth[v0]=0;
        for(i=0; i<n-1; i++)
        {
            wmin=tmin=inf;
            u=v0;
            for(j=0; j<n; j++)
            {
                if(!vis[j]&&dist[j]<=wmin)
                {
                    if(dist[j]==wmin)
                    {
                        if(worth[j]<tmin)
                        {
                            u=j;
                            wmin=dist[j];
                            tmin=worth[j];
                        }
                    }
                    else
                    {
                        u=j;
                        wmin=dist[j];
                        tmin=worth[j];
    
                    }
                }
            }
            vis[u]=1;
            for(k=0; k<n; k++)
            {
                if(!vis[k]&&edge[u][k].w<inf&&dist[u]+edge[u][k].w<=dist[k])
                {
                    if(dist[u]+edge[u][k].w==dist[k])
                    {
                        if(worth[u]+edge[u][k].t<worth[k])
                        {
                            dist[k]=dist[u]+edge[u][k].w;
                            path[k]=u;
                            worth[k]=worth[u]+edge[u][k].t;
                        }
                    }
                    else
                    {
                        dist[k]=dist[u]+edge[u][k].w;
                        path[k]=u;
                        worth[k]=worth[u]+edge[u][k].t;
    
                    }
                }
            }
        }
    }
    int main()
    {
        int i,j,k,m,s,d,u,v,w,t;
        while(~scanf("%d%d%d%d",&n,&m,&s,&d))
        {
            memset(edge,0,sizeof(edge));
            for(i=0; i<m; i++)
            {
                scanf("%d%d%d%d",&u,&v,&w,&t);
                edge[u][v].w=edge[v][u].w=w;
                edge[u][v].t=edge[v][u].t=t;
            }
    
            for(i=0; i<n; i++)
                for(j=0; j<n; j++)
                {
                    if(i==j) edge[i][j].w=0;
                    else if(edge[i][j].w==0) edge[i][j].w=inf;
                }
            dijkstra(s);
            printf("%d %d
    ",dist[d],worth[d]);
        }
        return 0;
    }

    版权声明:本文为博主原创文章,未经博主允许不得转载。http://xiang578.top/

  • 相关阅读:
    Django REST Framework之版本控制
    Django REST Framework之频率限制
    webpack4进阶配置
    高阶函数map,filter,reduce的用法
    Vue+elementui 实现复杂表头和动态增加列的二维表格
    Pika源码学习--pika和rocksdb的对接
    Pika源码学习--pika的命令执行框架
    Pika源码学习--pika的PubSub机制
    Pika源码学习--pika的通信和线程模型
    pika源码学习--开篇
  • 原文地址:https://www.cnblogs.com/xryz/p/4847994.html
Copyright © 2020-2023  润新知