1107. Social Clusters 解析

2023-11-26 15:58
文章标签 解析 social clusters 1107

本文主要是介绍1107. Social Clusters 解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

兴趣圈,并查集的问题。

把爱好用并查集来处理,处理完了,再将人按爱好进行分类。统计。


#include <iostream>
#include <vector>
#include <set>
#include <algorithm>
#include <cstring>#define MAX 1010using namespace std;int hobbie[MAX];
set <int> cluster;
set <int> h;
int n;
int c[MAX];struct people {vector <int> hobbie;
};
people p[MAX];void Init() {for (int i = 0; i < MAX; i++) {hobbie[i] = i;}
}void Compress(int n,int top) {if (hobbie[n] != top) {Compress(hobbie[n], top);hobbie[n] = top;}
}int Find(int n) {if (hobbie[n] != n) {int top = Find(hobbie[n]);Compress(n, top);}return hobbie[n];
}void Union(int n1, int n2) {int a = Find(n1);int b = Find(n2);
//	cout << n1 << " " << a << " || " << n2 << " " << b << endl;if (a != b) {hobbie[a] = b;
//		cout << a << " -> " << b << endl;}
}bool cmp(int n1, int n2) {return n1 > n2;
}int main() {cin >> n;Init();memset(c, 0, sizeof(c));int times, temp;for (int i = 0; i < n; i++) {cin >> times;cin.get();int head;cin >> head;p[i].hobbie.push_back(head);h.insert(head);for (int j = 1; j < times; j++) {cin >> temp;p[i].hobbie.push_back(temp);h.insert(temp);Union(head, temp);head = Find(temp);}}set <int>::iterator it;for (it = h.begin(); it != h.end(); it++) {cluster.insert(Find(*it));}for (int i = 0; i < n; i++) {c[Find(p[i].hobbie[0])]++;}sort(c, c + MAX, cmp);cout << cluster.size() << endl;cout << c[0];for (int i = 1; i < cluster.size(); i++) {cout << " " << c[i];}cout << endl;return 0;}


这篇关于1107. Social Clusters 解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/425970

相关文章

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Java解析JSON的六种方案

《Java解析JSON的六种方案》这篇文章介绍了6种JSON解析方案,包括Jackson、Gson、FastJSON、JsonPath、、手动解析,分别阐述了它们的功能特点、代码示例、高级功能、优缺点... 目录前言1. 使用 Jackson:业界标配功能特点代码示例高级功能优缺点2. 使用 Gson:轻量

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象