P1396 营救(并查集+二分)
2024-10-20 05:35:26
思路:检验函数中,先初始化每个节点的下标,每调用检验函数就从新使用一次并查集(并查集的时间复杂度非常低),然后,就看当一条路的价值val<=假设最大值x时,就把他们连接起来。
#include<iostream>
#include<algorithm>
using namespace std; const int maxn = 1e4 + ;
int n, m, s, t, st[maxn << ], en[maxn << ], val[maxn << ];
int l = maxn, r, ans, mid, fa[maxn];
//并查集
int getfa(int x){
if (fa[x] == x)return x;
return fa[x] = getfa(fa[x]);
}
//并查集判断
bool find(int x, int y){
return getfa(x) == getfa(y);
}
//并查集合并
void H_(int x, int y){
if (!find(x, y))fa[getfa(x)] = fa[getfa(y)];
}
bool check(int x){
for (int i = ; i <= n; ++i)fa[i] = i;
for (int i = ; i <= m;++i)
if (val[i] <= x)H_(st[i], en[i]);
return find(s, t);
} void half(){
while (l <= r){
mid = (l + r) >> ;
if (check(mid)){ ans = mid; r = mid - ; }
else l = mid + ;
}
} int main(){
cin >> n >> m >> s >> t;
for (int i = ; i <= m; ++i)
{
cin >> st[i] >> en[i] >> val[i];
l = min(l, val[i]); r = max(r, val[i]);
}
half(); //二分
cout << ans << endl;
}
最新文章
- iOS开发 - OC - 实现本地数据存储的几种方式二(直接使用sqlite)
- Linq使用Group By 1
- [iOS翻译]《iOS7 by Tutorials》系列:iOS7的设计精髓(上)
- Android开发之模拟器的选择
- Topcoder Srm627 DIV 2
- NOI 2015 T1 等式
- 二分法查找(Binary Search)
- magento xml配置详解
- linux下挂载NTFS分区错误修复
- hihoCoder 1257 Snake Carpet(很简单的构造方法)
- ubuntu下python flask环境搭建
- 微信网页授权封装接口——node.js版
- Linux系统管理命令(1)accton的使用
- Unity自动切割动画
- synchronized关键字用法
- Java的背景、影响及前景
- QTP_随机生成N个字符(包含数字和字母)
- Android-认识Service
- Android实践项目汇报-改(一)
- Cache写机制:Write-through与Write-back