http://poj.org/problem?id=1838

并查集,,,计算总共个数的模版。。。。。

 #include <iostream>
#define maxn 16006
#include<algorithm>
using namespace std; struct node{
int x,y;
int index;
}q[maxn]; int f[maxn],rank[maxn],sum[maxn]; void init(int n){
for(int i=;i<=n;i++){
f[i] = i;
rank[i]=;
}
} bool cmp_x(node a, node b){
if(a.x==b.x)
return a.y<b.y;
return a.x<b.x;
} bool cmp_y(node a,node b){
if(a.y==b.y)
return a.x<b.x;
return a.y<b.y;
}
bool cmp(int x, int y){
return x>y;
} int find(int x){
if(x!=f[x])
f[x] = find(f[x]);
return f[x];
} void unin(int x, int y){
int fx = find(x);
int fy = find(y);
if(fx==fy)
return;
if(rank[fx]>rank[fy]){
rank[fx] += rank[fy];//求共有多少节点
f[fy] = fx;
}
else {
rank[fy] += rank[fx];
f[fx] = fy; }
return ;
} int main()
{
int n , k;
while(cin>>n>>k){
init(n);
for(int i=;i<=n;i++){
cin>>q[i].x>>q[i].y;
q[i].index=i;
}
sort(q+,q++n,cmp_x);//合并x方向
for(int i=;i<n;i++){
if(q[i].x==q[i+].x&&q[i].y+==q[i+].y)
unin(q[i].index,q[i+].index);
}
sort(q+,q++n,cmp_y);//合并y方向
for(int i=;i<n;i++){
if(q[i].y==q[i+].y&&q[i].x+==q[i+].x)
unin(q[i].index,q[i+].index);
}
int cnt =;
for(int i=;i<=n;i++){//取出f[i]==i的节点
if(f[i]==i)
sum[cnt++] = rank[i];
}
sort(sum,sum+cnt,cmp);//找出k个
int ssum =;
for(int i=;i<k;i++)
ssum += sum[i];
cout<<ssum<<endl;
}
return ;
}

poj 1838的更多相关文章

  1. POJ 1838 Banana (并查集)

    Description Consider a tropical forrest, represented as a matrix. The cell from the right top corner ...

  2. POJ1838

    poj 1838 这道题主要是对并查集的考察,在这道题的解题过程中主要用到的算法就是并查集中的最基本的makeSet,findSet,unionSet 即前篇文章中所提到的: makeSet(Elem ...

  3. POJ 题目分类(转载)

    Log 2016-3-21 网上找的POJ分类,来源已经不清楚了.百度能百度到一大把.贴一份在博客上,鞭策自己刷题,不能偷懒!! 初期: 一.基本算法: (1)枚举. (poj1753,poj2965 ...

  4. (转)POJ题目分类

    初期:一.基本算法:     (1)枚举. (poj1753,poj2965)     (2)贪心(poj1328,poj2109,poj2586)     (3)递归和分治法.     (4)递推. ...

  5. poj分类

    初期: 一.基本算法:      (1)枚举. (poj1753,poj2965)      (2)贪心(poj1328,poj2109,poj2586)      (3)递归和分治法.      ( ...

  6. poj 题目分类(1)

    poj 题目分类 按照ac的代码长度分类(主要参考最短代码和自己写的代码) 短代码:0.01K--0.50K:中短代码:0.51K--1.00K:中等代码量:1.01K--2.00K:长代码:2.01 ...

  7. POJ题目分类(按初级\中级\高级等分类,有助于大家根据个人情况学习)

    本文来自:http://www.cppblog.com/snowshine09/archive/2011/08/02/152272.spx 多版本的POJ分类 流传最广的一种分类: 初期: 一.基本算 ...

  8. POJ题目分类(转)

    初期:一.基本算法:     (1)枚举. (poj1753,poj2965)     (2)贪心(poj1328,poj2109,poj2586)     (3)递归和分治法.     (4)递推. ...

  9. POJ题目细究

    acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP:  1011   NTA                 简单题  1013   Great Equipment     简单题  102 ...

随机推荐

  1. uva 719 Glass Beads(后缀自动机)

    [题目链接] https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=524&am ...

  2. POJ 3581 Sequence(后缀数组)

    [题目链接] http://poj.org/problem?id=3581 [题目大意] 给出一个数列,将这个数列分成三段,每段分别翻转,使得其字典序最小,输出翻转后的数列. [题解] 首先,第一个翻 ...

  3. Linux-NGINX 能否添加P3P头,如何添加。 - 德问:编程社交问答

    Linux-NGINX 能否添加P3P头,如何添加. - 德问:编程社交问答   您的投票让 杜鑫 声誉值增加5分. 支持投票,不仅能让提问用户获得声誉值,让好的问题有更多的曝光,更能帮助社区筛选出好 ...

  4. STC15?MSP430?ARM?DSP?

    自从大学毕业以来,发现属于自己的时间越来越少,每天忙于工作,导致在大学学到的东西都好生疏,特别是大一刚开始学的模电,单片机等,现在才慢慢的抓起来,然后在这个多核处理器流行的时代,单片机貌似快过时了,但 ...

  5. JS闭包经典例题

    上一篇文章谈论了闭包的概念和一些应用,并给出一个例题,这篇文章就此道例题进行讨论. function fun(n,o) { console.log(o); return { fun:function( ...

  6. SSIS DB目录设置 (Integration Services Catalogs)

    1.创建SSISDB目录 这里没什么好说的,点击Enable CLR Integration ,然后设置一个加密密码 2. SSIS Catalog设置 Retention Period (days) ...

  7. ubuntu下使用codeblocks

    集成开发环境搭建 1. 安装build-essential 方法: sudo apt-get install build-essential 作用:提供编译程序必须软件包的列表信息,编译程序有了这个软 ...

  8. java集合分析(转载)

    参考文章:浅谈Java中的Set.List.Map的区别 Java 7 Collections详解 java中集合分为三类: Set(集) List(列表) Map(映射) Set和List继承自Co ...

  9. C——货物管理系统

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <conio.h> ...

  10. 读取IOS的相应路径

    //    IOS相应路径 NSString* bundlePath = [[NSBundle mainBundle] bundlePath]; NSLog(@"bundlePath = % ...