【刷题】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; }
------------恢复内容结束------------
标签:int,memset,long,最短,------------,刷题,P1613,dis 来源: https://www.cnblogs.com/xwww666666/p/16128358.html