(step5.1.5)hdu 1856(More is better——DFS)
来源:互联网 发布:淘宝店音乐怎么设置 编辑:程序博客网 时间:2024/06/08 19:27
题目大意:输入一个整数n,表示有n对朋友,接下来给出n对朋友。。。输出最大的集合中的人数(即,秋季喝的最大的秩)
解题思路:并查集
1)按秩的大小来插。即
if( fx != fy){//这里根据秩的大小来插入if(rank[fx] > rank[fy]){rank[fx] += rank[fy];father[fy] = fx;}else{rank[fy] += rank[fx];father[fx] = fy;}}
2)需要求出秩的最大值
int max = -1;for( i = 1 ; i<= 10000001 ; ++i){if(rank[i] > max){max = rank[i];}}
/* * 1856_2.cpp * * Created on: 2013年8月23日 * Author: Administrator */#include <iostream>using namespace std;/** * father[i] :用来保存当前节点的父亲节点 * rank[i] :用来保存当前节点的秩(即当前节点包含了多少节点) * */int father[10000001];int rank[10000001];int find(int a){if( a == father[a]){return a;} father[a] = find(father[a]); return father[a];}void join(int x , int y){int fx = find(x);int fy = find(y);if( fx != fy){//这里根据秩的大小来插入if(rank[fx] > rank[fy]){rank[fx] += rank[fy];father[fy] = fx;}else{rank[fy] += rank[fx];father[fx] = fy;}}}void make_set(){int i;for( i = 1 ; i<= 10000001 ; ++i){father[i] = i;rank[i] = 1;}}int main(){int n;while(scanf("%d",&n)!=EOF){memset(rank,0,sizeof(rank));memset(father,0,sizeof(father));make_set();int i;for( i = 1 ; i <= n ; ++i ){int a,b;scanf("%d%d",&a,&b);join(a,b);}//以下代码用来求秩的最大值int max = -1;for( i = 1 ; i<= 10000001 ; ++i){if(rank[i] > max){max = rank[i];}}printf("%d\n",max);}}
- (step5.1.5)hdu 1856(More is better——DFS)
- hdu——1856—— More is better
- hdu 1856 More is better
- HDU 1856 more is better
- Hdu-1856 More is better
- hdu 1856 More is better
- hdu 1856 More is better
- hdu 1856 More is better
- HDU 1856 More is better
- HDU 1856 More is better
- HDU 1856 More is better
- HDU 1856 More is better
- hdu 1856 More is better
- hdu 1856 More is better
- HDU 1856 More is better
- hdu 1856 More is better
- hdu 1856 More is better
- HDU 1856 More is better
- 返回值为类名的虚函数 覆盖
- 基本数据结构之线性表-顺序表
- SharedPreferences介绍:
- java冒泡排序、选择排序、插入排序算法的核心思想及其比较
- Python 拷贝对象(深拷贝deepcopy与浅拷贝copy)
- (step5.1.5)hdu 1856(More is better——DFS)
- poj 2888 Magic Bracelet 置换(Burnside引理)+矩阵
- Windows 下单机最大TCP连接数
- <<黑马程序员>>java基础之泛型
- dom4j中xpath的使用
- MFC可编辑CListCtrl
- Sobel edge detection
- LeetCode - Minimum Depth of Binary Tree
- SSH集成框架的页面数据回显