【刷题】P1613跑路

2022/4/11 6:13:02

本文主要是介绍【刷题】P1613跑路,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

 

//原本以为这题只需要floyd得到dis[1][n]
//然后拆分出二进制中1的个数 (这里是不是有个函数可以用)
//但是样例显示此题不是普通最短路,要求的是时间最短而不是路程最短

//那么在不改动的情况下,也许可以寻找环? 

#include<bits/stdc++.h>
#define ll long long
using namespace std;

int n,m;
const int N=60,M=1e4+10;
int dis[N][N];

int u[M],v[M]; 
vector <int > e[N];

int main()
{
    cin>>n>>m;
    memset(dis,0x3f3f3f,sizeof(dis) ); 
    for(int i=1;i<=n;i++) dis[i][i]=0;
    for(int i=1;i<=m;i++)
    {
        cin>>u[i]>>v[i];
        dis[u[i]][v[i]]=1;
    }
    
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            for(int k=j+1;k<=n;k++)
            {
                dis[j][k] = min(dis[j][k],dis[j][i]+dis[i][k] );
                dis[k][j] = min(dis[k][j],dis[k][i]+dis[i][j] );
            }
        }
    }
    
    int ans=dis[1][n],cnt=0;
    for(int i=1;ans>=i;i<<=1)
        if(ans&i) cnt++;
    cout<<ans<<endl;
    
    cout<<cnt;
    return 0;
}

 

------------恢复内容结束------------



这篇关于【刷题】P1613跑路的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程