【数据结构】:由小米的一道面试题入手并查集

本文通过分析小米面试中的一道题目——求解朋友圈数量,引入并查集这一数据结构。首先,简单介绍了使用哈希解决此类问题的方法,然后详细阐述了并查集的概念,以及如何运用并查集高效地解决面试题中的问题。最后,总结了并查集的特点和常见应用,如连通子图和最小生成树算法等。
摘要由CSDN通过智能技术生成

小米的面试题

  • 1、题目:
    假如已知有n个人和m对好友关系(存于数字r),如果两人是直接或间接好友(好友的好友的好友….),则认为他们属于同一个朋友圈,请写程序求出这n个人里一共有多少个朋友圈。
    例如:n=5,m=3,r={ {1,2},{2,3},{4,5}},表示有5个人,1和2是好友,2和3是好友,4和5是好友,则1,2,3,属于一个朋友圈,4,5属于另一个朋友圈。结果为2个朋友圈。
  • 2、怎么解决?拿到这道题有什么思路?别着急,我们可以用学过的数据结构来进行分析这道题。
    • 首先我们很容易想到哈希,利用哈希桶来进行做这道题,那么如何实施
    • 用vector进行存储人,如果有几个人,我们就存储几个,但是当有交集,也就是说当是好友关系的时候,放进桶里,最终统计vector里面的个数
    • 针对这道题就是:首先是1,那么放进vector,再是2因为2是1的好友,就放进桶里,接着进行遍历数组,遍历到3,3是2的好友,就将3链接到2的后面,当遇到4的时候,放进vector中,到5,接到4的下面,最终统计出vector里面的数,就是2,因此有两个朋友圈。
  • 3、这种方法可解但是我们仔细想想,时间复杂度是很高的,实现起来也是很麻烦的,因此我们想想有没有一种新的方法可以降低时间复杂度,很好的进行实现的,于是就出现了一种新的数据结构:并查集。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值