2019-03-17 等待戈多

時(shí)間限制: 1Sec 內(nèi)存限制: 128MB 提交: 264 解決: 19

題目描述
戈多是一個(gè)普通的小盆友,他居住在1城市。小x在k城等待戈多。

可惜戈多有點(diǎn)奇怪,在城市之間的道路上,他的速度有時(shí)快有時(shí)慢。

現(xiàn)在小x想知道,戈多最快到達(dá)的時(shí)間是多少?

輸入
第一行是兩個(gè)數(shù)字n(n<=500),k,表示城市的個(gè)數(shù)和小x的位置。

接下來(lái)是一個(gè)正整數(shù)的矩陣l,第i行第j列表示i到j(luò)的路徑長(zhǎng)度。

接下來(lái)是一個(gè)正整數(shù)的矩陣v,表示戈多從i到j(luò)路徑所走的速度。

輸出
輸出一個(gè)浮點(diǎn)數(shù),表示戈多最快到達(dá)的時(shí)間,保留兩位小數(shù)
樣例輸入
6 3
0 5 3 6 2 4
5 0 1 7 10 3
3 1 0 8 9 4
6 7 8 0 2 6
2 10 9 2 0 5
4 3 4 6 5 0
0 1 4 5 6 3
1 0 5 7 9 6
4 5 0 3 2 4
5 7 3 0 1 1
6 9 2 1 0 8
3 6 4 1 8 0
樣例輸出
0.75
提示
無(wú)

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const int maxn=510;
double G[maxn][maxn];
bool vis[maxn];
int pre[maxn];
double d[maxn];
int n,k;
double INF=0x7FFFFFFF;
void dijkstra(int s)
{
    for(int i=1;i<=n;i++) d[i]=INF,pre[i]=i;
    d[s]=0;
    for(int i=1;i<=n;i++)
    {
        int u=-1,MIN=INF;
        for(int j=1;j<=n;j++)
        {
            if(vis[j]==false && d[j]<MIN)
            {
                u=j;
                MIN=d[j];
            }
        }
        if(u==-1) return ;
        vis[u]=true;
        for(int v=1;v<=n;v++)
        {
            if(vis[v]==false && G[u][v]!=INF &&  d[u]+G[u][v]<d[v])
            {
                d[v]=d[u]+G[u][v];
                pre[v]=u;
            }
        }
    }
}
int main(void)
{
    //freopen("D:\\input1.txt","r",stdin);
    while(cin>>n>>k)
    {
        fill(vis,vis+maxn,0);
        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=n;j++)
            {
                cin>>G[i][j];
            }
        }
        
        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=n;j++)
            {
                double v;
                cin>>v;
                if(i!=j && v!=0)
                {
                    G[i][j]=G[i][j]/v;
                }
                else 
                {
                    G[i][j]=INF;    
                } 
            }
        }
        dijkstra(1);
        printf("%.2lf",d[k]);
    }
    return 0;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 前些天加班了。心態(tài)非常平和,因?yàn)槭且黄鹱龅膱?bào)告,竟然找到了一種在學(xué)校里teamwork探討的感覺(jué),內(nèi)心升騰起小小的...
    西角虹明閱讀 152評(píng)論 0 0

友情鏈接更多精彩內(nèi)容