【刷题】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跑路的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解
- 2024-11-23Java对接阿里云智能语音服务入门教程
- 2024-11-23JAVA对接阿里云智能语音服务入门教程
- 2024-11-23Java副业入门:初学者的简单教程
- 2024-11-23JAVA副业入门:初学者的实战指南