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

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

题目要求:

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

例如,在 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] 都包含有且仅有一个 '@' 字符。

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

解题代码:

static const int _ = []() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    return 0;
}();
class Solution {
public:
    int numUniqueEmails(vector<string>& emails) {
        vector<string>save;
        string str;
        int i,j,flag;
        //save.push_back(str);//想不起来有什么作用了
        for(i=0;i<emails.size();i++){
            flag=0;
            for(j=0;j<emails[i].length();j++){
                if(emails[i][j]=='.')continue;
                else if(emails[i][j]=='@')break;
                else if(emails[i][j]=='+'){
                    while(emails[i][j]!='@')
                        j++;
                    break;
                }
                else str.push_back(emails[i][j]);
            }
            j++;
            for(;j<emails[i].length();j++)
                str.push_back(emails[i][j]);
            for(int k=0;k<save.size();k++)
                if(save[k]==str)flag=1;
            if(flag==0)save.push_back(str);
            str.clear();
        }
        return save.size()-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<string>& emails) {
        unordered_set<string> 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();
	}

运行结果:

还行吧。

posted @ 2019-03-23 15:21  1000sakura  阅读(241)  评论(0编辑  收藏  举报