-
Notifications
You must be signed in to change notification settings - Fork 40
/
UniqueEmailAddresses.js
65 lines (60 loc) · 2.14 KB
/
UniqueEmailAddresses.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
// Source : https://leetcode.com/problems/unique-email-addresses
// Author : Dean Shi
// Date : 2018-11-10
/***************************************************************************************
*
* Every email consists of a local name and a domain name, separated by the @ sign.
*
* For example, in alice@leetcode.com, alice is the local name, and leetcode.com is the
* domain name.
*
* Besides lowercase letters, these emails may contain '.'s or '+'s.
*
* If you add periods ('.') between some characters in the local name part of an email
* address, mail sent there will be forwarded to the same address without dots in the
* local name. For example, "alice.z@leetcode.com" and "alicez@leetcode.com" forward
* to the same email address. (Note that this rule does not apply for domain names.)
*
* If you add a plus ('+') in the local name, everything after the first plus sign will
* be ignored. This allows certain emails to be filtered, for example m.y+name@email.
* com will be forwarded to my@email.com. (Again, this rule does not apply for domain
* names.)
*
* It is possible to use both of these rules at the same time.
*
* Given a list of emails, we send one email to each address in the list. How many
* different addresses actually receive mails?
*
* Example 1:
*
* Input: ["test.email+alex@leetcode.com","test.e.mail+bob.cathy@leetcode.com","
* testemail+david@lee.tcode.com"]
* Output: 2
* Explanation: "testemail@leetcode.com" and "testemail@lee.tcode.com" actually receive
* mails
*
* Note:
*
* 1 <= emails[i].length <= 100
* 1 <= emails.length <= 100
* Each emails[i] contains exactly one '@' character.
*
*
***************************************************************************************/
/**
* @param {string[]} emails
* @return {number}
*/
var numUniqueEmails = function(emails) {
return new Set(emails.map(parseEmail)).size
};
function parseEmail(email) {
let parsedEmail = ''
let [address, hostname] = email.split('@')
for (let a of address) {
if (a === '.') continue
if (a === '+') break
parsedEmail += a
}
return `${parsedEmail}@${hostname}`
}