题目链接

题目描述

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

输入格式:

输入第一行给出一个正整数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. 基于 Jmeter 的 web 端接口自动化测试平台

    简介 基于之前的react+unittest+flask的接口自动化平台开发经验,和趟过的坑,我重新开发了这个接口自动化平台.平台前端采用的antd+dva+umi的antd-pro模板,结合平台业务 ...

  2. javascript获取当前日期和时间

    ){ ){ _time = year+"-"+month+"-"+date+" "+hour+":"+minu+&quo ...

  3. equals比较对象

    object类的equals方法用来比较是否是同一个对象,比较内存地址. jdk中有些类重写了equals方法,只要类型,内容相同,就相等. 类如果涉及到比较应该重写equals方法,比较内存地址没有 ...

  4. scala 有 + 运算符吗? - 03

    scala 有运算符吗? 答案是没有. package com.msym /** * Created by ACER on 2017/7/4. */ object Demo { def main(ar ...

  5. 反射就是获取该类的.class文件里面的方法,属性

    反射就是获取该类的.class文件里面的方法,属性

  6. 【刷题】BZOJ 2157 旅游

    Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间 ...

  7. ListView嵌套webView 事件冲突解决

    如图,红色部分为WebView,作为ListView头部存在,测试视频(h5)要左右滑动,ListView要上下滑动,保证视频控件和下面评论部分可以显示,但是这个时候就存在WebView横向滑动和Li ...

  8. bzoj2146 Construct

    题目描述 随着改革开放的深入推进…… 小T家要拆迁了…… 当对未来生活充满美好憧憬的小T看到拆迁协议书的时候,小T从一位大好的社会主义青年变成了绝望的钉子户. 由于小T的家位于市中心,拆迁工作又难以进 ...

  9. (转)解决dubbox-demo-provider.xml报错的问题:提示Failed to read schema document

    背景:在eclipse项目中,经常会遇到xml文件提示找不到.xsd文件的情况.很有必要弄清xsd文件的加载过程! 1 解决过程 dubbo-demo-provider导入eclipse后dubbox ...

  10. python之旅:面向对象之继承与派生

    一 初识继承 编写类时,并非总要从空白开始.如果你要编写的类正好是另一个现成类的特殊版本,可使用继承来减少代码冗余,子类会“遗传”父类的属性,从而解决代码重用问题 什么是继承 继承是一种创建新类的方式 ...