博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1251 Jungle Roads(最小生成树简单题)
阅读量:4046 次
发布时间:2019-05-25

本文共 927 字,大约阅读时间需要 3 分钟。

题意分析:

模板题了吧。

#include
#include
#include
#include
using namespace std;#define MAX 30struct edge { int u, v, cost; };bool cmp(const edge& e1, const edge& e2) { return e1.cost < e2.cost; }vector
es;//边集合int fa[MAX];//并查集int n;//顶点数int find(int x) { return fa[x] == -1 ? x : fa[x] = find(fa[x]); }//并查集查找 路径压缩int kk(){ int cnt = 0; sort(es.begin(), es.end(), cmp);//对边进行排序 memset(fa, -1, sizeof(fa));//并查集初始化 int res = 0; for (int i = 0; i < es.size(); i++) { if (find(es[i].u) != find(es[i].v))//不在同一个连通分量 { fa[find(es[i].u)] = find(es[i].v);//unite res += es[i].cost; } } return res;}int main(){ int n; while (cin >> n,n) { es.clear(); for (int i = 0; i < n - 1; i++) { char c1, c2; int k,v,d; cin >> c1 >> k; while (k--) { cin >> c2 >> d; v = c2 - 'A'; edge tmp = { i,v,d }; es.push_back(tmp); } } cout << kk() << endl; } system("pause");}

转载地址:http://fuyci.baihongyu.com/

你可能感兴趣的文章
pidgin-lwqq 安装
查看>>
mint/ubuntu安装搜狗输入法
查看>>
C++动态申请数组和参数传递问题
查看>>
opencv学习——在MFC中读取和显示图像
查看>>
C/C++中关于动态生成一维数组和二维数组的学习
查看>>
JVM最简生存指南
查看>>
Java的对象驻留
查看>>
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
持续可用与CAP理论 – 一个系统开发者的观点
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
c++字符数组和字符指针区别以及str***函数
查看>>
c++类的操作符重载注意事项
查看>>
c++模板与泛型编程
查看>>
WAV文件解析
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
WPF UI&控件免费开源库
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
Ubuntu+win10远程桌面
查看>>
flutter-实现圆角带边框的view(android无效)
查看>>