Caocao's Bridges(割边)
#include<iostream>
#include<stack>
#include<vector>
#include<cstring>
struct edge{
int x,y,z;
};
const int N=1e3+5;
std::vector<int>v[N];
std::vector<edge>e;
int n,m,low[N],dfsn[N],a,b,c,MIN,t;
void add(int a,int b,int c){
e.push_back({a,b,c});
v[a].push_back(e.size()-1);
}
void dfs(int x,int fa){
low[x]=dfsn[x]=++t;
for(int i=0;i<v[x].size();i++){
int j=v[x][i],y=e[j].y,z=e[j].z;
if(!dfsn[y]){
dfs(y,j);
low[x]=std::min(low[x],low[y]);
if(low[y]>dfsn[x])MIN=std::min(MIN,z);
}
else if(j!=(fa^1))low[x]=std::min(low[x],dfsn[y]);
}
}
int main(){
std::ios::sync_with_stdio(0);
std::cin.tie(0);
std::cout.tie(0);
while(std::cin>>n>>m){
if(!n&&!m)break;
while(m--){
std::cin>>a>>b>>c;
add(a,b,c);
add(b,a,c);
}
MIN=1e9;
t=0;
int cnt=0;
memset(low,0,sizeof(low));
memset(dfsn,0,sizeof(dfsn));
for(int i=1;i<=n;i++){
if(!dfsn[i]){
dfs(i,0);
cnt++;
}
}
if(n==1||cnt>1)std::cout<<0<<'\n';//注意这个
else if(MIN==1e9)std::cout<<-1<<'\n';
else std::cout<<std::max(MIN,1)<<'\n';
e.clear();
for(int i=1;i<=n;i++)v[i].clear();
}
return 0;
}
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合终身会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 提升Avalonia UI质感,跨平台图标库选型实践
· 突发,CSDN 崩了!程序员们开始慌了?
· C# 中委托和事件的深度剖析与应用场景
· 一个基于 .NET 8 + Ant Design Blazor 开发的简洁现代后台管理框架
· AppBox拖拽设计增删改查用户界面