HDU 2066 一个人的旅行(Dijkstra)


  • 原题链接:Here!

  • 分析:和草儿家相邻的城市的有S个,草儿想去的地方有D个。所以这个问题起点集合是S{},终点集合是D{}。我们只需要计算出每一个起点到所有终点的最短距离,然后选出其中最小的距离就是答案。

  • 注意:输入时会出现重边,需要对重边进行处理。

  • CODE:
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    const int maxn = 1000+10;
    const int inf  = 0x3f3f3f;
    
    int G[maxn][maxn];
    int vis[maxn];
    int dis[maxn];
    int T,S,D;						// T条路,和草儿家相邻的城市的有S个,草儿想去的地方有D个
    
    void Dijkstra(int s){			//时间复杂度为0(n^2),用于1000点    
        memset(vis,0,sizeof(vis));  
        vis[s]=1;					  
        for(int i=1;i<=1000;i++) 	dis[i]=G[s][i];			
        for(int i=1;i<1000;i++){	
            int k=-1 , minn=inf;  
            for(int j=1;j<=1000;j++){ 
                if(!vis[j]&&dis[j]<minn){
                    k=j;	minn=dis[j];  
                }  
            }  
            if(k==-1)  	return ;  
            vis[k]=1;  
            for(int j=1;j<=1000;j++){
                if(!vis[j]&&dis[j]>G[k][j]+dis[k])   
                    dis[j]=G[k][j]+dis[k];
            }  
        }  
    } 
    int main(){
    	while(scanf("%d%d%d",&T,&S,&D)!=EOF){
    		memset(G,inf,sizeof(G));
    		for(int i=1;i<=T;i++){
    			int a,b,time;
    			scanf("%d%d%d",&a,&b,&time);
    			G[a][b]=G[b][a]=min(time,G[a][b]);		// 处理重边 
    		}
    		
    		int start[maxn],aim[maxn];					// 起点集和终点集 
    		for(int i=0;i<S;i++)	scanf("%d",&start[i]);
    		for(int i=0;i<D;i++)	scanf("%d",&aim[i]);
    		
    		int min_len=inf;
    		for(int i=0;i<S;i++){
    			Dijkstra(start[i]);
    			for(int j=0;j<D;j++)
    				if(min_len>dis[aim[j]])	min_len=dis[ aim[j] ]; 
    			memset(dis,0,sizeof(dis));
    		}
    		printf("%d\n",min_len);
    	} 
    	return 0;
    }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值