【BZOJ】【P3714】【PA2014】【Kuglarz】【题解】【最小生成树】
2014-09-25 18:39
344 查看
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3714
前缀和奇偶性
Code:
#include<bits/stdc++.h>
using namespace std;
const int maxn=2e3+10;
struct edge{
int u,v,w;
bool operator<(const edge &E)const{
return w<E.w;
}
}edges[maxn*maxn];
int fa[maxn];
int find(int x){
if(fa[x]!=x)return fa[x]=find(fa[x]);
return x;
}
int n,m;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)fa[i]=i;
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j++){
int x;
scanf("%d",&x);
edges[++m]=(edge){i-1,j,x};
}
}sort(edges+1,edges+1+m);
long long ans=0;
for(int i=1;i<=m;i++){
int u=edges[i].u,v=edges[i].v;
if(find(u)!=find(v)){
fa[find(u)]=find(v);
ans+=edges[i].w;
}
}cout<<ans<<endl;
return 0;
}
前缀和奇偶性
Code:
#include<bits/stdc++.h>
using namespace std;
const int maxn=2e3+10;
struct edge{
int u,v,w;
bool operator<(const edge &E)const{
return w<E.w;
}
}edges[maxn*maxn];
int fa[maxn];
int find(int x){
if(fa[x]!=x)return fa[x]=find(fa[x]);
return x;
}
int n,m;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)fa[i]=i;
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j++){
int x;
scanf("%d",&x);
edges[++m]=(edge){i-1,j,x};
}
}sort(edges+1,edges+1+m);
long long ans=0;
for(int i=1;i<=m;i++){
int u=edges[i].u,v=edges[i].v;
if(find(u)!=find(v)){
fa[find(u)]=find(v);
ans+=edges[i].w;
}
}cout<<ans<<endl;
return 0;
}
相关文章推荐
- 【BZOJ3714】【PA2014】Kuglarz(最小生成树)
- BZOJ 3714: [PA2014]Kuglarz(最小生成树)
- 最小生成树 BZOJ3714 [PA2014]Kuglarz
- 【bzoj3714: [PA2014]Kuglarz】转化 ---最小生成树
- BZOJ3714 [PA2014]Kuglarz 【最小生成树】
- 【BZOJ 3714】[PA2014]Kuglarz 最小生成树
- bzoj 3714: [PA2014]Kuglarz【最小生成树】
- 【kruscal】【最小生成树】【并查集扩展】bzoj3714 [PA2014]Kuglarz
- 【bzoj3714】【PA2014】【Kuglarz】【最小生成树】
- 【BZOJ3714】【PA2014】Kuglarz(最小生成树)
- 【BZOJ3714】[PA2014]Kuglarz 最小生成树
- BZOJ 3714 [PA2014]Kuglarz - 最小生成树模型
- bzoj 3714: [PA2014]Kuglarz 最小生成树
- 【BZOJ 4144】[AMPPZ2014]Petrol 最短路+最小生成树
- 【BZOJ3669】[Noi2014]魔法森林【Link-Cut Tree】【最小生成树】
- BZOJ3714 [PA2014]Kuglarz
- BZOJ 3714: [PA2014]Kuglarz
- 【Kruskal+DFS】BZOJ1016(JSOI2008)[最小生成树计数]题解
- BZOJ 3479: [Usaco2014 Mar]Watering the Fields(最小生成树)
- bzoj 4144 [AMPPZ2014]Petrol 最短路+最小生成树+倍增