题目链接

就是裸的最小生成树,复习一下。

prim算法:

G=(V,E),V是点集,E是边集

假设T=(U,TE)是最小生成树。U,TE初始化为空

首先从V中任取一点 假设取V1,然后U={V1},只要U是V的真子集,就从那些一个端点在T中,一个端点在T外的边中,找一条最短边。一直下去,直到找到n-1条边

找边使用 堆优化,复杂度(ElogV) 邻接表复杂度(V2

 #include<cstdio>
#include<vector>
#include<queue>
#include<cstring>
using namespace std;
const int maxn=;
const int inf=0x3f3f3f3f; struct node{
int v,dis;
node(){}
node(int _v,int _dis){
v=_v;
dis=_dis;
}
bool operator<(const node &b) const {
return dis>b.dis;
}
}; int n,dis[maxn];
vector<node> G[maxn];
bool vis[maxn]; void prim() {
int ans=,num=;
priority_queue<node> pq;
for(int i=;i<n;i++) {
vis[i]=false;
dis[i]=inf;
}
pq.push(node(,));
node f;
while(num<n&&!pq.empty()) {
do{
f=pq.top();
pq.pop();
}while(vis[f.v]&&!pq.empty());
if(!vis[f.v]) {
ans+=f.dis;
vis[f.v]=true;
num++;
for(int i=;i<G[f.v].size();i++) {
int v=G[f.v][i].v;
if(!vis[v]) {
if(dis[v]>G[f.v][i].dis) {
dis[v]=G[f.v][i].dis;
pq.push(node(v,dis[v]));
}
}
}
}
}
if(num<n) printf("-1\n");//因为这里记录的是点的个数。不是边
else printf("%d\n",ans);
} int main() {
while(~scanf("%d",&n)) {
memset(G,,sizeof(G));
for(int i=;i<n;i++) {
for(int j=;j<n;j++) {
int x;
scanf("%d",&x);
if(x) G[i].push_back(node(j,x));
}
}
prim();
}
}

krusual算法:

将图G中的边按权值从小到大选取,使选取的不与生成树构成回路。直到n-1条边为止

判断回路就用并查集搞一下。

 #include<cstdio>
#include<vector>
#include<queue>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=;
const int inf=0x3f3f3f3f; int n;
struct Edge{
int u,v,dis;
Edge(){}
Edge(int _u,int _v,int _dis) {
u=_u;
v=_v;
dis=_dis;
}
bool operator <(const Edge &b) const {
return dis<b.dis;
}
}; vector<Edge> edge; int fa[maxn]; int Find(int x) {
if(fa[x]==-) return x;
else return fa[x]=Find(fa[x]);
} void Union(int x,int y) {
int fx=Find(x);
int fy=Find(y);
if(fx!=fy) {
fa[fx]=fy;
}
} int main() {
while(~scanf("%d",&n)) {
memset(fa,-,sizeof(fa));
edge.clear();
for(int i=;i<n;i++) {
for(int j=;j<n;j++) {
int x;
scanf("%d",&x);
if(x&&j<i) edge.push_back(Edge(i,j,x));
}
}
sort(edge.begin(),edge.end());
int num=,ans=;
for(int i=;i<edge.size();i++) {
int u=edge[i].u,v=edge[i].v,dis=edge[i].dis;
if(Find(u)!=Find(v)) {
num++;
ans+=dis;
Union(u,v);
}
}
if(num==n-) printf("%d\n",ans);
else printf("-1\n");
}
}

POJ1358 Agri-Net的更多相关文章

  1. Agri Net POJ1258 && Constructing Roads POJ2421

    题意,在给出的图中,使用最小花费的边,使这个图仍然连通. #include <cstdio> #include <algorithm> #include <cstring ...

  2. UI中经常出现的下拉框下拉自动筛选效果的实现

    小需求是当你在第一个下拉框选择了国家时,会自动更新第二个省份的下拉框,效果如下 两个下拉选择Html如下: <select id="country_select"> & ...

  3. 告别无止境的增删改查:Java代码生成器

    对于一个比较大的业务系统,我们总是无止境的增加,删除,修改,粘贴,复制,想想总让人产生一种抗拒的心里.那有什么办法可以在正常的开发进度下自动生成一些类,配置文件,或者接口呢?   有感于马上要做个比较 ...

  4. A过的题目

    1.TreeMap和TreeSet类:A - Language of FatMouse ZOJ1109B - For Fans of Statistics URAL 1613 C - Hardwood ...

  5. 告别无止境的增删改查--Java代码生成器

    转自:http://www.cnblogs.com/zhuYears/archive/2012/02/29/2373491.html 告别无止境的增删改查--Java代码生成器 有感于马上要做个比较大 ...

  6. 网络-05-端口号-F5-负载均衡设-linux端口详解大全--TCP注册端口号大全备

    [root@test1:Standby] config # [root@test1:Standby] config # [root@test1:Standby] config # [root@test ...

  7. Mybatis中 Integer 值为0时,默认为空字符串的解决办法。

    需求是查询级别为0的用户 User对象里的level字段的值为0,查询时居然没有查到为level为0的用户. <select id="selectSelective" par ...

  8. CentOS 7 服务端口表

    # Note that it is presently the policy of IANA to assign a single well-known# port number for both T ...

  9. etymon word air aero aeri aer ag agreement walk joint trick skill chief forget out~1

      1● air 2● aero 3● aeri 4● aer 空气 充气       1● ag     做,代理做   =====>agency       1● agr 2● agri 3 ...

随机推荐

  1. NMS:Non-maximum Suppression学习笔记

    非极大值抑制可看成一种局部极大值搜索,这里的局部极大值要比他的邻域值都要大.这里的邻域表示有两个参数:维度和n-邻域.维度有1-D,2-D,3-D...:至于n值根据具体情况设置.举个例子:一维的情况 ...

  2. 【原】Coursera—Andrew Ng机器学习—课程笔记 Lecture 5 Octave Tutorial—5.4 绘制数据图

    5.4 绘制数据图 参考视频: 5 - 4 - Plotting Data (10 min) 5.4.1 绘制曲线 1.画一个sin曲线 >> t = [:0.01:0.98]; > ...

  3. 对象序列化中transient关键字的用途

  4. 使用class-dump

    [使用class-dump] 对于未加壳的Mach-O文件,class-dump可以从Mach-O的section中还原出objc代码的头文件.下面做一些关键演示,以及对关键问题进行说明. 1.标准用 ...

  5. 在Ubuntu上源码安装NodeJS

    Refer http://nqdeng.github.io/7-days-nodejs/#7.1 前提条件: 确保系统下g++版本(g++ -v)在4.6以上,python版本(python --ve ...

  6. NEERC17 J Journey from Petersburg to Moscow

    CF上可以提交.   链接 依然是很妙的解法. 我们可以枚举每一个出现过的边权$L$,然后把所有边的边权减掉这个$L$,如果小于$L$就变为$0$,然后跑一遍最短路然后加上$k * L$更新答案即可. ...

  7. 如何偷Android的内存-Tricking Android MemoryFile

    之前在做一个内存优化的时候,使用到了MemoryFile,由此发现了MemoryFile的一些特性以及一个非常trickly的使用方法,因此在这里记录一下 What is it MemoryFile是 ...

  8. Claims Based Authentication and Token Based Authentication和WIF

    基于声明的认证方式,其最大特性是可传递(一方面是由授信的Issuer,即claims持有方,发送到你的应用上,注意信任是单向的.例如QQ集成登录,登录成功后,QQ会向你的应用发送claims.另一方面 ...

  9. Convert HTML to PDF with New Plugin

    FROM:http://www.e-iceblue.com/Tutorials/Spire.PDF/Spire.PDF-Program-Guide/Convert-HTML-to-PDF-with-N ...

  10. RPLiDAR 激光雷达探测地面高程

    LiDAR,又称激光探测与测量,全程Light Detection And Ranging,这种技术使用激光测量地物(如森林和建筑物)的高程.它的原理十分类似于使用声波来测绘海底地形的声呐技术,或使用 ...