Battle Over Cities - Hard Version
1001 Battle Over Cities - Hard Version
思路:暴力跑每一个点作为被侵略点的情况,求最小生成树即可。
需要注意的情况是,虽然题目说最一开始的时候图是联通的,但是要注意,当一个点被侵略的时候,图可能就不连通了,所以需要判定一下,不连通的情况置为 inf。
// Created by CAD on 2021/5/18.
#include <bits/stdc++.h>
#define fi first
#define se second
#define inf 0x3f3f3f3f
#define pii pair<int,int>
using namespace std;
const int maxn=6e6+5;
struct edge{
int u,v,w;
bool operator <(edge &e){
return w<e.w;
}
}e[maxn];
int f[505];
int find(int x){
return f[x]==x?x:f[x]=find(f[x]);
}
int n,m;
vector<pii> ans;
void solve(int x){
for(int i=1;i<=n;++i)
f[i]=i;
int cnt=0,sum=0;
for(int i=1;i<=m;++i){
int u=e[i].u,v=e[i].v,w=e[i].w;
if(u==x||v==x||find(u)==find(v)) continue;
cnt++,sum+=w,f[find(u)]=find(v);
}
if(cnt<n-2) sum=inf;
if(ans.empty()) ans.emplace_back(x,sum);
else {
if(ans[0].se>sum) return ;
if(ans[0].se<sum) ans.clear();
ans.emplace_back(x,sum);
}
}
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n>>m;
for(int i=1;i<=m;++i){
int u,v,w,t;cin>>u>>v>>w>>t;
e[i]={u,v,(t==0)?w:0};
}
sort(e+1,e+m+1);
for(int i=1;i<=n;++i)
solve(i);
if(ans.empty()||ans[0].se==0) cout<<0<<endl;
else{
for(int i=0;i<ans.size();++i){
cout<<ans[i].fi<<" \n"[i==ans.size()-1];
}
}
return 0;
}
CAD加油!欢迎跟我一起讨论学习算法,QQ:1401650042
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
2020-05-18 得到某个位置的迭代器