持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第12天,点击查看活动详情
一、题目与题目分析
题目
每个有效电子邮件地址 都由一个 本地名 和一个 域名 组成,以 '@' 符号分隔。除小写字母之外,电子邮件地址还可以含有一个或多个 '.' 或 '+' 。
- 例如,在
alice@leetcode.com中, alice 是 本地名 ,而leetcode.com是 域名 。 如果在电子邮件地址的 本地名 部分中的某些字符之间添加句点('.'),则发往那里的邮件将会转发到本地名中没有点的同一地址。请注意,此规则 不适用于域名 。 - 例如,
alice.z@leetcode.com和alicez@leetcode.com会转发到同一电子邮件地址。 如果在 本地名 中添加加号('+'),则会忽略第一个加号后面的所有内容。这允许过滤某些电子邮件。同样,此规则 不适用于域名 。 - 例如
m.y+name@email.com将转发到my@email.com。 可以同时使用这两个规则。
给你一个字符串数组 emails,我们会向每个 emails[i] 发送一封电子邮件。返回实际收到邮件的不同地址数目。
(题目来源:力扣:929. 独特的电子邮件地址)
题目分析
看示例可以知道,email字符串都是由小写英文字母、+、.、@组成,再由多个email组成String[]字符串数组。
为此,我们主要需要针对单个email字符串去处理。
- ① 先根据
@进行切割; - ② 再切割已经被
@切割的前半段,用带+的,不要后面一截; - ③ 同时,也把
.去掉。 省流分析:解析字符串。
二、整体逻辑与主要代码
题目分析已经比较清楚了,接下来我们进入代码设计。
整体逻辑
整体逻辑就是根据题目分析已经好的,二切,一丢;+和@是二切,.是一丢。
主要代码
整体逻辑清晰了之后,同时也有较清楚的注释。直接来看代码吧! (如有不懂的或者更好的建议,欢迎评论区分享友友的看法哈~)
public static int numUniqueEmails(String[] emails) {
// 存在不可重复的Email(实现唯一性)
Set<String> sendEmailSet = new HashSet<>();
for (String email : emails) { // 遍历emails
// 定义一个StringBuilder(减少新的实例)
StringBuilder sendEmail = new StringBuilder();
// 找到@的位置,进行切割
int em = email.indexOf('@');
// 也可以直接使用split,email.split("@");
// 切割前半段,本地名(不带@)
String localName = email.substring(0, em);
// 切割后半段,域名(带@)
String domainName = email.substring(em);
for (int i = 0; i < localName.length(); i++) {
// 遍历本地名
if (localName.charAt(i) == '.'){
// 遇到 `.` 的字符,跳过
continue;
}
if (localName.charAt(i) == '+'){
// 遇到 `+`的字符,打断跳出
break;
}
// 添加当前字符(除`.`和`+`之后的字符(包括`+`))
sendEmail.append(localName.charAt(i));
}
// 添加域名(带@)
sendEmail.append(domainName);
// 存入set
sendEmailSet.add(sendEmail.toString());
}
// 返回发送email的数量
return sendEmailSet.size();
}
三、结果展示
四、总结
一开始想到简单的操作是HashMap去做;后来才去学了一下Set,因为,Set是Java中的集合类,提供了一种无顺序,不重复的集合。
最后,选择使用HashSet.
题目数据库
Gitee:传送门
文章小尾巴
文章写作、模板、文章小尾巴可参考:《写作“小心思”》
感谢你看到最后,最后再说两点~
①如果你持有不同的看法,欢迎你在文章下方进行留言、评论。
②如果对你有帮助,或者你认可的话,欢迎给个小点赞,支持一下~
我是南方者,一个热爱计算机更热爱祖国的南方人。
(文章内容仅供学习参考,如有侵权,非常抱歉,请立即联系作者删除。)