Leetcode 721. 账户合并 (略有难度比较绕的并查集问题)

 

 

这道题目比较有难度,名字允许相同,对应不同的邮箱,邮箱相同一定对应同一个账户,一个账户可能有多个邮箱,

所以如何标记一个账户?直接用编号id

首先我们使用一个HashMap,从邮箱映射到id,一旦发现有相同的邮箱时,就用并查集把id连起来,并查集维护的是id。


但是答案,要求的是id对应邮箱,因此我们需要在建立一个hashmap,里面是id,对应邮箱集合。

我们遍历之前的map,找到邮箱和id,通过并查集将id对应到根节点的id。

然后得到id,邮箱集合数组,由于通过遍历hashmap得到,所以邮箱数组一定不会有重复。

最后,我们再遍历一次id,邮箱数组,然后将数据加入答案数组,这题总体逻辑比较绕,面试中第一次见难度很大。

 

class Union{
private:
    vector<int> p;
    int n;
public:
    Union(){}
    Union(int n){
        this->
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值