每封电子邮件都由一个本地名称和一个域名组成,以 @ 符号分隔。
例如,在 alice@leetcode.com中, alice 是本地名称,而 leetcode.com 是域名。
除了小写字母,这些电子邮件还可能包含 ‘.’ 或 ‘+’。
如果在电子邮件地址的本地名称部分中的某些字符之间添加句点(’.’),则发往那里的邮件将会转发到本地名称中没有点的同一地址。例如,"alice.z@leetcode.com” 和 “alicez@leetcode.com” 会转发到同一电子邮件地址。 (请注意,此规则不适用于域名。)
如果在本地名称中添加加号(’+’),则会忽略第一个加号后面的所有内容。这允许过滤某些电子邮件,例如 m.y+name@email.com 将转发到 my@email.com。 (同样,此规则不适用于域名。)
可以同时使用这两个规则。
给定电子邮件列表 emails,我们会向列表中的每个地址发送一封电子邮件。实际收到邮件的不同地址有多少?
示例:
输入:[“test.email+alex@leetcode.com”,“test.e.mail+bob.cathy@leetcode.com”,“testemail+david@lee.tcode.com”]
输出:2
解释:实际收到邮件的是 "testemail@leetcode.com" 和 "testemail@lee.tcode.com"。
提示:
1 <= emails[i].length <= 100
1 <= emails.length <= 100
每封 emails[i] 都包含有且仅有一个 ‘@’ 字符。
class Solution(object):
def numUniqueEmails(self, emails):
"""
:type emails: List[str]
:rtype: int
"""
email_set = set()
for email in emails:
# 利用split函数把元素在@处分开,返回一个包含两个元素的列表,分别是name和地址
email = email.split('@')
# 将列表中第一个元素中的'.'替换为空,相当于删除
email_left = email[0].replace('.','')
name = ''
for i in email_left:
if i != '+':
name+=i
else:
break
email = name+'@'+''.join(email[1])
email_set.add(email)
return len(email_set)
class Solution(object):
def numUniqueEmails(self, emails):
"""
:type emails: List[str]
:rtype: int
"""
# 用列表来储存处理过的电子邮件地址
emails_pro = []
for email in emails:
# 对列表中的每一个邮件地址
# 首先去掉[+:@]之间的元素(因为会涉及到@对应的索引问题,所以先操作这一步),j为@的索引
email = list(email)
j = email.index('@')
n = len(email)
i = 0
# 如果@之前的元素没有+,就退出循环
while i<j:
# 如果找到+,就删除[+:@]之间的元素并退出循环
if email[i] == '+':
del email[i:j]
break
i += 1
# 重新获得@的索引,因为我们要删除@之前的'.'
j = email.index('@')
for p in email[:j]:
if p == '.':
email.remove(p)
emails_pro.append(''.join(email))
# 最终对处理之后的电子邮件地址去重,返回列表长度
return len(set(emails_pro))