题目链接

题目描述

给定每个人的家庭成员和其自己名下的房产,请你统计出每个家庭的人口数、人均房产面积及房产套数。

输入格式:

输入第一行给出一个正整数N(<=1000),随后N行,每行按下列格式给出一个人的房产:

编号 父 母 k 孩子1 ... 孩子k 房产套数 总面积

其中 编号 是每个人独有的一个4位数的编号;父 和 母 分别是该编号对应的这个人的父母的编号(如果已经过世,则显示-1);k(0<=k<=5)是该人的子女的个数;孩子i是其子女的编号。

输出格式:

首先在第一行输出家庭个数(所有有亲属关系的人都属于同一个家庭)。随后按下列格式输出每个家庭的信息:

家庭成员的最小编号 家庭人口数 人均房产套数 人均房产面积

其中人均值要求保留小数点后3位。家庭信息首先按人均面积降序输出,若有并列,则按成员编号的升序输出。

输入样例:

10

6666 5551 5552 1 7777 1 100

1234 5678 9012 1 0002 2 300

8888 -1 -1 0 1 1000

2468 0001 0004 1 2222 1 500

7777 6666 -1 0 2 300

3721 -1 -1 1 2333 2 150

9012 -1 -1 3 1236 1235 1234 1 100

1235 5678 9012 0 1 50

2222 1236 2468 2 6661 6662 1 300

2333 -1 3721 3 6661 6662 6663 1 100

输出样例:

3

8888 1 1.000 1000.000

0001 15 0.600 100.000

5551 4 0.750 100.000

分析:

可以发现家族成员间关系的处理应用并查集就可以解决,但是关键在于对于家族中的房产信息处理。

我们用一个人的编号来唯一的表示一个人,用编号作为下标来记录这个人有没有出现过。对于所有的出现过的人的编号,找到他所在的并查集的根节点(也就是它本身的父节点),令其父节点所在家庭的人数加一,并且在此时计算家中的人均房产数和人均房产面积。最终排序后输出所需要的东西即可。

代码:

#include<stdio.h>
#include<iostream>
#include<algorithm>
using namespace std;
struct Person
{
int id;//一个人的id
int h_num;//拥有的房产数
int h_s;//拥有的房产面积
} person[10009]; struct Family
{
int id;//家中最小的成员id
int f_num;//成员个数
int h_num;//家庭房产数
int h_s;//家庭房产面积
double avg_h;//平均房产数
double avg_s;//平均房产面积
} family[10009]; bool cmp(Family a,Family b)
{
if(a.avg_s==b.avg_s)
return a.id<b.id;
return a.avg_s>b.avg_s;
} int pre[10009];//父节点
int vis[10009];//标记这个编号的人有没有出现过 int find_pre(int x)
{
while(x!=pre[x])
x=pre[x];
return x;
} void unin(int x,int y)
{
int px=find_pre(x);
int py=find_pre(y);
if(px!=py)
pre[px]=py;
} void init()
{
for(int i=0; i<10000; i++)
{
pre[i]=i;
family[i].id=0;
family[i].f_num=0;
family[i].h_num=0;
family[i].h_s=0;
family[i].avg_h=0;
family[i].avg_s=0;
vis[i]=0;
}
}
int main()
{
init();
int n,a,b,c,k,child;
scanf("%d",&n);
for(int i=0; i<n; i++)
{
scanf("%d%d%d",&a,&b,&c);//本身和双亲的编号
vis[a]=1;
if(b!=-1)//父亲存在
{
vis[b]=1;
unin(a,b);
}
if(c!=-1)//母亲存在
{
vis[c]=1;
unin(a,c);
}
scanf("%d",&k);//孩子的个数,并且要建立联系
for(int j=0; j<k; j++)
{
scanf("%d",&child);
vis[child]=1;
unin(a,child);
}
person[i].id=a;
scanf("%d%d",&person[i].h_num,&person[i].h_s);
}
for(int i=0; i<n; i++)
{
int Id=find_pre(person[i].id);//家族的编号
family[Id].h_num+=person[i].h_num;
family[Id].h_s+=person[i].h_s;
}
for(int i=0; i<10000; i++)
{
if(vis[i]==1)//该人存在
{
pre[i]=find_pre(i);
if(family[pre[i]].f_num==0)//这里保证了此时的家庭的id就是家中的所有人的最小编号
{
family[pre[i]].id=i;
}
family[pre[i]].f_num++;
family[pre[i]].avg_h=family[pre[i]].h_num*1.0/family[pre[i]].f_num;
family[pre[i]].avg_s=family[pre[i]].h_s*1.0/family[pre[i]].f_num;
}
}
sort(family,family+10000,cmp);
int ans=0;
for(int i=0;i<n;i++)
{
if(family[i].f_num!=0)
ans++;
else
break;
}
printf("%d\n",ans);
for(int i=0;i<ans;i++)
printf("%04d %d %.3lf %.3lf\n",family[i].id,family[i].f_num,family[i].avg_h,family[i].avg_s);
return 0;
}

天梯赛 L2-007. (并查集) 家庭房产的更多相关文章

  1. 天梯赛 L2-024. (并查集) 部落

    题目链接 题目描述 在一个社区里,每个人都有自己的小圈子,还可能同时属于很多不同的朋友圈.我们认为朋友的朋友都算在一个部落里,于是要请你统计一下,在一个给定社区中,到底有多少个互不相交的部落?并且检查 ...

  2. 天梯赛 L2-013. (并查集) 红色警报

    题目链接 题目描述 战争中保持各个城市间的连通性非常重要.本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报.注意:若该国本来就不完全连通,是分裂的k个区域 ...

  3. PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)

    PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中) 实现语言:C/C++:      欢迎各位看官交流讨论.指导题解错误:或者分享更快的方法!! 题目链接:https://pintia.cn/ ...

  4. Travel(HDU 5441 2015长春区域赛 带权并查集)

    Travel Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total Su ...

  5. PTA天梯赛L2

    L2-001 紧急救援 题意:就是给你一张n<500的图:让你求最短路径,最短路条数,以及路径: 做法,先用dijkstra求最短路,然后dfs找最短路条数,以及点权的最大值: 一般dfs不就可 ...

  6. 蓝桥杯模拟赛 引爆炸弹-并查集+DFS

    引爆炸弹 在一个 n×m的方格地图上,某些方格上放置着炸弹.手动引爆一个炸弹以后,炸弹会把炸弹所在的行和列上的所有炸弹引爆,被引爆的炸弹又能引爆其他炸弹,这样连锁下去. 现在为了引爆地图上的所有炸弹, ...

  7. 2019湘潭校赛 G(并查集)

    要点 题目传送 题目本质是每个点必属于两个集合中的一个,伴随的性质是:如果一个人说别人true,则他们一定属于同一阵营:如果说别人fake,一定不属于同一阵营. 每个点拆为\(i\)和\(i + n\ ...

  8. 团体程序设计天梯赛-练习集L2-007. 家庭房产

    L2-007. 家庭房产 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 给定每个人的家庭成员和其自己名下的房产,请你统计出每个 ...

  9. 天梯赛决赛 L2-1.红色警报 并查集

    L2-013. 红色警报 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 战争中保持各个城市间的连通性非常重要.本题要求你编写一 ...

随机推荐

  1. PHP 官方发行版扩展下载地址

    PHP扩展下载 稳定发行版资源下载地址: https://windows.php.net/downloads/pecl/releases/ 常用扩展: 持续更新中 ... igbinary序列化/反序 ...

  2. pyqt5 eric6

    1 安装Anaconda3 2 python环境变量改为Anaconda3中python 3 pip安装pyqt5 ,pip安装pyqt5-tool 其中tool中包含eric6 ui文件必须使用的d ...

  3. [转帖] CentOS7 与 CentOS6的对比

    来源网站: http://blog.51cto.com/fengery/1901349 centos6.x_centos7.x差异改进明细 感谢原作者 centos官方帮助文档:https://wik ...

  4. [转帖]HTTPS的简单说明

    HTTPS(全称:Hyper Text Transfer Protocol over SecureSocket Layer),是以安全为目标的 HTTP 通道,简单讲是 HTTP 的安全版,即 HTT ...

  5. 计算机网络【9】—— HTTP1.0和HTTP1.1的区别及常见状态码

    一.HTTP1.0与HTTP1.1的区别 1.HTTP 1.1支持长连接(PersistentConnection)和请求的流水线(Pipelining)处理 HTTP 1.0规定浏览器与服务器只保持 ...

  6. URL query string中文字符问题

    如果URL的query string中包含中文字符,在不做特殊处理的情况下通过 request.getParameter 方法是获取不到正确的信息的,这是由于下面的两个机制造成的 浏览器会自动对URL ...

  7. SGU438_The Glorious Karlutka River =)

    好题,有一些人在河的一边,想通过河里的某些点跳到对岸去.每个点最多只能承受一定数量的人,每人跳跃一次需要消耗一个时间.求所有人都过河的最短时间. 看网上说是用了什么动态流的神奇东东.其实就是最大流吧, ...

  8. nowcoder 203J Graph Coloring I(dfs)

    题目链接 题目描述 修修在黑板上画了一些无向连通图,他发现他可以将这些图的结点用两种颜色染色,满足相邻点不同色. 澜澜不服气,在黑板上画了一个三个点的完全图.修修跟澜澜说,这个图我能找到一个简单奇环. ...

  9. 关于BIO和NIO的理解

    摘要: 关于BIO和NIO的理解 最近大概看了ZooKeeper和Mina的源码发现都是用Java NIO实现的,所以有必要搞清楚什么是NIO.下面是我结合网络资料自己总结的,为了节约时间图示随便画的 ...

  10. 【刷题】BZOJ 2301 [HAOI2011]Problem b

    Description 对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数. Input 第一行一个整数 ...