【LeetCode】Unique Email Addresses(独特的电子邮件地址)

这道题是LeetCode里的第929道题。

题目要求:

每封电子邮件都由一个本地名称和一个域名组成,以 @ 符号分隔。

例如,在 [email protected]中, alice 是本地名称,而 leetcode.com 是域名。

除了小写字母,这些电子邮件还可能包含 '.' 或 '+'

如果在电子邮件地址的本地名称部分中的某些字符之间添加句点('.'),则发往那里的邮件将会转发到本地名称中没有点的同一地址。例如,"[email protected] 和 [email protected] 会转发到同一电子邮件地址。 (请注意,此规则不适用于域名。)

如果在本地名称中添加加号('+'),则会忽略第一个加号后面的所有内容。这允许过滤某些电子邮件,例如 [email protected] 将转发到 [email protected]。 (同样,此规则不适用于域名。)

可以同时使用这两个规则。

给定电子邮件列表 emails,我们会向列表中的每个地址发送一封电子邮件。实际收到邮件的不同地址有多少?

 

示例:

输入:["[email protected]","[email protected]","[email protected]"]
输出:2
解释:实际收到邮件的是 "[email protected]" 和 "[email protected]"。

 

提示:

  • 1 <= emails[i].length <= 100
  • 1 <= emails.length <= 100
  • 每封 emails[i] 都包含有且仅有一个 '@' 字符。

这道题目很简单,对@前的特殊字符进行 if 条件转移就大功告成了。

解题代码:

static const int _ = []() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    return 0;
}();
class Solution {
public:
    int numUniqueEmails(vector& emails) {
        vectorsave;
        string str;
        int i,j,flag;
        //save.push_back(str);//想不起来有什么作用了
        for(i=0;i

提交结果:

【LeetCode】Unique Email Addresses(独特的电子邮件地址)_第1张图片

个人总结: 

之前写的代码,可以优化,可以把结果保存在一个 set 里面,简化代码。最简代码:

static int desyncio = []() {
    std::ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    return 0;
}();
class Solution {
public:
    int numUniqueEmails(vector& emails) {
        unordered_set set;
        for (auto &s : emails) {
            unsigned int p, a;
            while (p = s.find('.'), a = s.find('@'), p != std::string::npos && p < a)
                s.erase(p, 1);
            if (p = s.find('+'), a = s.find('@'), p != std::string::npos && p < a)
                s.erase(p, a - p);
            set.insert(s);
        }
        return set.size();
    }
};

最最最实用的方法(并不是):正则表达式。

	public static int numUniqueEmails(String[] emails) {
		return (int)Arrays.stream(emails).map(a1 ->{
			a1 = a1.replaceAll("\\+.*@", "@");
			while(a1.matches(".*\\..*@.*")) {
				a1 = a1.replaceFirst("\\.","");
			}
			return a1;
		}).distinct().count();
	}

运行结果:

【LeetCode】Unique Email Addresses(独特的电子邮件地址)_第2张图片

还行吧。

你可能感兴趣的:(LeetCode,C/C++,字符串,正则表达式,LeetCode)