博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1258 Agri-Net (Prim&Kruskal)
阅读量:5167 次
发布时间:2019-06-13

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

题意:FJ想连接光纤在各个农场以便网络普及,现给出一些连接关系(给出邻接矩阵),从中选出部分边,使得整个图连通。求边的最小总花费。

思路:裸的最小生成树,本题为稠密图,Prim算法求最小生成树更优,复杂度O(n^2)

prim:

#include 
#include
#include
#include
using namespace std;int mat[110][110];bool vis[110];int d[110];int Prim(int n) { int ans = 0; int p = 0; vis[0] = 1; for (int j = 1; j < n; ++j) { d[j] = mat[p][j]; } for (int i = 1; i < n; ++i) { p = -1; for (int j = 1; j < n; ++j) { if (vis[j]) continue; if (p == -1 || d[j] < d[p]) { p = j; } } ans += d[p]; vis[p] = 1; for (int j = 1; j < n; ++j) { if (vis[j]) continue; d[j] = min(d[j], mat[p][j]); } } return ans;}int main() { int n, i, j; while (scanf("%d", &n) != EOF) { memset(vis, 0, sizeof(vis)); for (i = 0; i < n; ++i) { for (j = 0; j < n; ++j) { scanf("%d", &mat[i][j]); } } int ans = Prim(n); printf("%d\n", ans); } return 0;}

kruskal:

#include 
#include
#include
#include
using namespace std;int N; // 节点数量struct edge { int from, to, dist; bool operator<(const edge &b) const { return dist < b.dist; }} es[10006];int par[105];void init() { for (int i = 1; i <= N; ++i) par[i] = i;}int find(int x) { return x == par[x] ? x : par[x] = find(par[x]);}void unite(int x, int y) { x = find(x); y = find(y); if (x != y) par[x] = y;}int kruskal() { int res = 0; init(); int E = N*N; sort(es + 1, es + 1 + E); for (int i = 1; i <= E; ++i) { edge e = es[i]; //printf("u:%d v:%d d:%d\n", e.from, e.to, e.dist); if (find(e.from) != find(e.to)) { unite(e.from, e.to); res += e.dist; } } return res;}void solve() { cout << kruskal() << endl;}int main(){ while (cin >> N) { int d; int id; for (int u = 1; u <= N; ++u) for (int v = 1; v <= N; ++v) { cin >> d; id = (u - 1)*N + v; es[id].from = u; es[id].to = v; es[id].dist = d; } solve(); } return 0;}

转载于:https://www.cnblogs.com/demian/p/7396670.html

你可能感兴趣的文章
删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005 ....
查看>>
一步一步写算法(之爬楼梯)
查看>>
SQL Server 多实例下的复制
查看>>
Wix打包系列(五) 部署数据库
查看>>
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(20)-权限管理系统-根据权限获取菜单...
查看>>
临时禁用Resharper
查看>>
[UML]UML系列——时序图(顺序图)sequence diagram
查看>>
EPPlus 读取 csv另存为的xlsx 文件出错
查看>>
【ASP.NET Web API教程】2.3.7 创建首页
查看>>
LINQ to Entities 不识别方法“System.String ToString()”,因此该方法无法转换为存储表达式。...
查看>>
每天进步一点点 用AJAX自动校验用户名是否与已有用户名重复
查看>>
正则表达式
查看>>
机器学习(四) SVM 支持向量机
查看>>
c 字符串 函数
查看>>
Android 拖动条/滑动条控件、星级评分控件
查看>>
Linux 使用pwgen命令创建随机密码
查看>>
Vmware esxi开启snmp服务
查看>>
LogLog
查看>>
Practice: Process logs with Apache Hadoop
查看>>
实验六
查看>>