码迷,mamicode.com
首页 > 其他好文 > 详细

hdu3665Seaside 最短路水题

时间:2015-07-28 10:44:27      阅读:108      评论:0      收藏:0      [点我收藏+]

标签:最短路

//给一个图,有些点近海,问从0点到近海点的最短路
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std ;
const int maxn = 100 ;
const int inf = 0x3f3f3f3f ;
int map[maxn][maxn] ;
int dis[maxn] ;
int vis[maxn] ;
int n , m ,pi;
int p[maxn] ;
void dijkstra()
{
    memset(vis , 0 , sizeof(vis)) ;
    for(int i = 1;i <= n;i++)
    dis[i] = inf ;
    dis[0] = 0 ;
    for(int i = 1;i <=n;i++)
    {
        int mi = inf ;
        int pos ;
        for(int j = 0;j <= n;j++)
        if(!vis[j] && dis[j] < mi)
        mi = dis[pos = j] ;
        vis[pos] = 1;
        for(int j = 1;j <= n;j++)
        dis[j] = min(dis[j] , dis[pos] + map[pos][j]) ;
    }
}
int main()
{
    while(~scanf("%d" ,&n))
    {
        for(int i = 0;i <= n;i++)
        for(int j = 0;j <= n;j++)
        map[i][j] = inf ;
        for(int i = 0;i < n;i++)
        {
            scanf("%d%d" ,&m ,&pi)  ;
            p[i] = pi ;
            while(m--)
            {
                int v , w;
                scanf("%d%d" ,&v , &w);
                map[i][v] = map[v][i] = w ;
            }
        }
        dijkstra() ;
        int ans = inf ;
        for(int i = 1;i <= n;i++)
        if(p[i])
        ans = min(ans , dis[i]) ;
        printf("%d\n" , ans) ;
    }
}




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

hdu3665Seaside 最短路水题

标签:最短路

原文地址:http://blog.csdn.net/cq_pf/article/details/47101511

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!