• 【刷题】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;
    }

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

  • 相关阅读:
    Java-Scanner
    Java-Stream File IO
    Java-方法
    Java-日期 正则表达式
    Java-数组
    Java-Character String StringBuffer StringBuilder
    Bootstrap栅格系统
    canvas-nest.js 设置网页背景
    Oracle数据库与MySQL的不同点
    java oop第15章_Socket网络编程
  • 原文地址:https://www.cnblogs.com/xwww666666/p/16128358.html
Copyright © 2020-2023  润新知