721. 账户合并

这篇博客介绍了如何解决LeetCode的721题——账户合并。作者首先解释了解题思路,包括对原始数据进行整合,使用唯一序号标识邮箱,并对相同名字的邮箱进行合并。然后,通过深度优先搜索(DFS)方法实现代码,最终得到合并后的账户列表,其中每个账户包含名称和有序的邮箱地址。
摘要由CSDN通过智能技术生成

给定一个列表accounts,每个元素 accounts[i] 是一个字符串列表,其中第一个元素 accounts[i][0] 是 名称 (name),其余元素是 emails 表示该账户的邮箱地址。

现在,我们想合并这些账户。如果两个账户都有一些共同的邮箱地址,则两个账户必定属于同一个人。请注意,即使两个账户具有相同的名称,它们也可能属于不同的人,因为人们可能具有相同的名称。一个人最初可以拥有任意数量的账户,但其所有账户都具有相同的名称。

合并账户后,按以下格式返回账户:每个账户的第一个元素是名称,其余元素是按顺序排列的邮箱地址。账户本身可以以任意顺序返回。

解题思路

1.先对原始数据进行整合, 对原始所有的邮箱进行编唯一序号, 对所有的邮箱存放名字
image.png
2.再次对原始数据进行遍历, 使用同一个名字下的邮箱通过唯一序号进行查并集合并
image.png
3.最终会归纳为三个独立的分支, 我们将同一个根的序号放到一起.
此时, 我们通过归纳后的index, 取到邮箱的主人名字, 很容易就得到答案了.

代码

class UnionFinder:
    def __init__(self, n):
        self.father = list(range(n))

    def find(self, x):
        if x != self.father[x]:
            self.father[x] = self.find(self.father[x])
        return<
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值