7-25 朋友圈 (25 分)(详解+并查集的了解和应用)

一:题目

某学校有N个学生,形成M个俱乐部。每个俱乐部里的学生有着一定相似的兴趣爱好,形成一个朋友圈。一个学生可以同时属于若干个不同的俱乐部。根据“我的朋友的朋友也是我的朋友”这个推论可以得出,如果A和B是朋友,且B和C是朋友,则A和C也是朋友。请编写程序计算最大朋友圈中有多少人。

输入格式:
输入的第一行包含两个正整数N(≤30000)和M(≤1000),分别代表学校的学生总数和俱乐部的个数。后面的M行每行按以下格式给出1个俱乐部的信息,其中学生从1~N编号:

第i个俱乐部的人数Mi(空格)学生1(空格)学生2 … 学生Mi

输出格式:
输出给出一个整数,表示在最大朋友圈中有多少人。

输入样例:
7 4
3 1 2 3
2 1 4
3 5 6 7
1 6
输出样例:
4

二:思路

利用并查集,求得根节点的得数组,再用map<int,int> 来计算当中重复次数多的个数 也就是根节点相同的个数最大值

三:上码


#include<bits/stdc++.h>
using namespace std;int father[30000]; //int find( int x){
//	
//	while( x != father[x] )
//	{
//		x = father[x];
//	}
//		
//	return x;		
//}//压缩路径
int find(int x){int r=x;while(father[r]!=r)r=father[r];		//找到他的前导结点int i=x,j;while(i!=r){	//路径压缩算法j=father[i];	//记录x的前导结点father[i]=r;	//将i的前导结点设置为r根节点i=j;}return r;
} void merge(int x,int y)
{int a = find(x);//x的根节点为a int b = find(y);//y的根节点为bif( a != b )father[b] = a;//那么将b的根节点  设为 a }int main()
{int N,M;cin >> N >> M;for( int i = 1; i <= N; i++ )father[i] = i;          //设置根节点为数组下标,另外元素值为索引  for( int j = 0; j < M; j++ ){int num;cin >> num;vector<int>v;for( int k = 0; k < num; k++ ){int numPeople;cin >> numPeople;v.push_back(numPeople);		}for( int i = 0; i < num-1; i++ ){if( find(v[i]) != find(v[i+1]) )merge(v[i],v[i+1]);//比如刚开始的 1和2 他们原来的根节点不同,所以合并 也就是将索引值为2的数组值改为1  即根节点值为1	}	}map<int,int>m;for( int i = 1; i <= N; i++){m[find(i)]++;	//这里是find(i)  不能是father[i] 否则最后一个测试点答案错误} map<int,int>:: iterator t;int max = 0;for(t = m.begin(); t!= m.end(); t++){if( max < t->second )max = t->second;}cout << max;}//7 4
//3 1 2 3
//2 1 4
//3 5 6 7
//1 6// 7 4
// 2 1 4
// 3 5 6 7
// 1 6 
// 3 1 2 3

在这里插入图片描述

四:并查集的相关知识

这道题用到了并查集,所以我就学了一下并查集,所以把自己的见解也分享给大家(建议 先看视频 再浏览 博客 再自己敲一遍 学习效率高而已,我总是乱着来 以为看几篇博客就会了,其实最后还是老老实实 去B站看大佬讲解视频 才搞懂)

1:并查集

查集是一种树型的数据结构,
用于处理一些不相交集合(Disjoint Sets)的合并及查询问题
1:查询元素a和元素b是否属于同一组
2:合并元素a和元素b所在组 (将有相同元素的元素 合并为一个组 )
3:需要初始化一个数组存放父节点,其索引值 代表元素

2:并查集的AC代码(模板`)

/*并查集是一种树型的数据结构,用于处理一些不相交集合(Disjoint Sets)的合并及查询问题1:查询元素a和元素b是否属于同一组2:合并元素a和元素b所在组 (将有相同元素的元素 合并为一个组 ) 3:需要初始化一个数组存放父节点,其索引值  代表元素 
*/#include<bits/stdc++.h>
using namespace std;int father[100]; int find( int x){while( x != father[x] ){x = father[x];}return x;		
} void merge(int x,int y)
{int a = find(x);//x的根节点为a int b = find(y);//y的根节点为bif( a != b )father[b] = a;//那么将b的根节点  设为 a }int main()
{//初始化: 我们将每一个结点的前导结点设置为自己,//如果在merge函数时未能形成连通,将独立成点for( int i = 0; i < 10; i++ ){father[i] = i;}}

上方的find函数 效率不高,当处理大数据时,使用并查集查找时,如果查找次数很多,那么使用朴素版的查找方式肯定要超时。比如,有一百万个元素,每次都从第一百万个开始找,这样一次运算就是106,如果程序要求查找个一千万次,这样下来就是1013,肯定要出问题的。

所以有了压缩路径的算法(就是一棵树只有叶节点)

void merge(int x,int y){int a=find(x);//x的根节点为aint b=find(y);//y的根节点为bif(a!=b)//如果a,b不是相同的根节点,则说明ab不是连通的pre[a]=b;//我们将ab相连 将a的前导结点设置为b
}

如有疑问 请留言! 加油陌生的你

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308437.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Azure人脸API对图片进行人脸识别

人脸识别是人工智能机器学习比较成熟的一个领域。人脸识别已经应用到了很多生产场景。比如生物认证&#xff0c;人脸考勤&#xff0c;人流监控等场景。对于很多中小功能由于技术门槛问题很难自己实现人脸识别的算法。Azure人脸API对人脸识别机器学习算法进行封装提供REST API跟…

java while do循环_c语言中,while 和 do while 循环的主要区别是( )

1、循环构造的表达式不同&#xff1a;while循环构造的表达式为&#xff1a;while(表达式)&#xff5b;循环体&#xff5d;。do&#xff0d;while循环构造表达式为&#xff1a;do&#xff5b;循环体&#xff1b;&#xff5d;while(条件表达)&#xff1b;。2、执行末尾循环体的次…

Java当中 IO(File) 操作 之 递归打印子孙级目录和文件名称

一&#xff1a;上码 package com.wyj.one;import java.io.File;/*** 列出下一级&#xff1a;* 1, list(): 列出下一级名称* 2&#xff0c; listFiles()&#xff1a;列出下一级File对象* 3, listRoots():列出盘符* author 86155**/ public class Demo8_列出下一级 {/*** p…

[NewLife.Net]单机400万长连接压力测试

目标对网络库NewLife.Net进行单机百万级长连接测试&#xff0c;并持续收发数据&#xff0c;检测网络库稳定性。【2020年8月1日晚上22点】先上源码&#xff1a;https://github.com/NewLifeX/NewLife.Net结论&#xff0c;8月1日晚达到200万&#xff0c;8月2日下午达到404万。上一…

JAVA开发需求分析套路_毕设做什么好?感觉都是套路了

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼在不考虑柯西序列的情况下&#xff1a;.1.00000000000000000……-0.9999999…….结果为 0.000…&#xff0c;也就是后面的 0 无限循环。这两个数目在这里是无限循环小数&#xff0c;小数点后五位之后还会一直填上 0&#xff0c;始终…

ABP快速开发一个.NET Core电商平台

总听.NETer羡慕Java有SSM框架&#xff0c;其实.NET也有ABP&#xff0c;极度优秀的开源应用程序框架&#xff0c;支持.NET Framework和.NET Core。羡慕Java有SpringCloud&#xff0c;其实.NET也有ABP.vNext&#xff0c;由ABP团队全新打造的.NET Core微服务架构开源框架&#xff…

Java当中 递归打印文件大小(面向不同的对象打印文件大小)

一&#xff1a;给固定的文件路径求文件大小 package com.wyj.one;import java.io.File;/*** 递归求出文件的大小* author 86155**/ public class CopyOfDemo10_递归打印子文件大小 {public static void main(String[] args) {File src new File("C:/Myjava/project12_IO…

java jlist 图标_java – 将图像添加到JList项目

您必须实现ListCellRenderer(或扩展DefaultListCellRenderer)并使用getListCellRendererComponent方法返回带有图标的Jlabel.例&#xff1a;public class IconListRenderer extends DefaultListCellRenderer {public Component getListCellRendererComponent(JList list, Objec…

Java当中编码和解码(以及出现乱编码的原因)

一&#xff1a;编码&#xff1a;字符串---->字节 package com.wyj.two;import java.io.UnsupportedEncodingException;/*** 编码&#xff1a;字符串-->字节* * * author 王永杰**/ public class Demo1_encode编码 {public static void main(String[] args) throws Unsup…

用了Dapper之后通篇还是SqlConnection,真的看不下去了

一&#xff1a;背景1. 讲故事前几天看公司一个新项目的底层使用了dapper&#xff0c;大家都知道dapper是一个非常强大的半自动化orm&#xff0c;帮程序员解决了繁琐的mapping问题&#xff0c;用起来非常爽&#xff0c;但我还是遇到了一件非常不爽的事情,如下代码所示&#xff1…

java swing 控件拖动_java swing中实现拖拽功能示例

java实现拖拽示例Swing中实现拖拽功能&#xff0c;代码很简单&#xff0c;都有注释&#xff0c;自己看&#xff0c;运行效果如下图&#xff1a;package com;import java.awt.*;import java.awt.datatransfer.DataFlavor;import java.awt.dnd.DnDConstants;import java.awt.dnd.…

7-26 Windows消息队列 (25 分)(详解+思路+超时解决)

一&#xff1a;题目 消息队列是Windows系统的基础。对于每个进程&#xff0c;系统维护一个消息队列。如果在进程中有特定事件发生&#xff0c;如点击鼠标、文字改变等&#xff0c;系统将把这个消息加到队列当中。同时&#xff0c;如果队列不是空的&#xff0c;这一进程循环地从…

一文说通C#中的异步编程补遗

前文写了关于C#中的异步编程。后台有无数人在讨论&#xff0c;很多人把异步和多线程混了。文章在这儿&#xff1a;一文说通C#中的异步编程所以&#xff0c;本文从体系的角度&#xff0c;再写一下这个异步编程。一、C#中的异步编程演变1. 异步编程模型这是C#中早期的异步模型&am…

java 视频监控 分屏ui_视频监控网页ActiveX视频分屏播放控件开发

最近在搞视频监控项目&#xff0c;需要在网页上显示实时视频&#xff0c;于是网上找了很多资料研究如何在网页上播放视频&#xff0c;一种实现方式就是开发activex控件嵌入到网页中。如下我将介绍如何开发一个可以分屏播放视频的activex控件 (部分内容也是从网上抄的&#xff0…

Java当中 文件得输入流 输出流

一&#xff1a;引言 InputStream 和 OutputStream 两个抽象类&#xff0c;我们主要用其实现类来操作 二&#xff1a;InputStream 输入流&#xff0c;从文件当中读数据到程序当中&#xff0c;我们要站在程序得角度上。 package com.wyj.two;import java.io.File; import jav…

基于.NetCore3.1系列 —— 日志记录之日志核心要素揭秘

前言在上一篇中&#xff0c;我们已经了解了内置系统的默认配置和自定义配置的方式&#xff0c;在学习了配置的基础上&#xff0c;我们进一步的对日志在程序中是如何使用的深入了解学习。所以在这一篇中&#xff0c;主要是对日志记录的核心机制进行学习说明。说明在上一篇中&…

array remove java_how to remove array from another array in javascript

可以将文章内容翻译成中文,广告屏蔽插件会导致该功能失效:问题:0: {id: 1553825061863, name: "Thai Milk Tea", qty: "1", total_amount: 9500, toppings: 500, …}1: {id: 1553825061863, name: "Thai Milk Tea", qty: "1", total_a…

Java 文件的拷贝

一&#xff1a;上码 package com.wyj.two;import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream;/*** 文件…

listview在java中的使用_我的Android开发之路——ListView的使用

在Android开发过程中&#xff0c;遇到需要列表显示的时候&#xff0c;这时候就会用到listview。1.首先创建一个ListViewTest项目&#xff0c;选择empty activity类型。修改activity_main.xml的布局文件&#xff0c;添加listview控件&#xff0c;设置宽高和id等属性此时通过预览…

如何利用NLog输出结构化日志,并在Kibana优雅分析日志?

上文我们演示了使用NLog向ElasticSearch写日志的基本过程(输出的是普通文本日志)&#xff0c;今天我们来看下如何向ES输出结构化日志、在Kibana中分析日志。什么是结构化日志&#xff1f;当前互联网、物联网、大数据突飞猛进&#xff0c;软件越复杂&#xff0c;查找任何给定问题…