内容简介:题目要求过滤重复的邮箱地址。最终返回不重复的用户名个数。过滤规则是:邮箱名中的
929. Unique Email Addresses
题目链接
题目分析
题目要求过滤重复的邮箱地址。最终返回不重复的用户名个数。
过滤规则是:邮箱名中的 .
要被忽略,且 +
后面的所有字符都要删去。域名部分则不进行处理。
思路
输入是一个数组,那么我们用 foreach
就可以了。
对于数组中的每一个元素,进行如下处理:
-
先以
@为分隔符拆分邮箱地址为用户名部分和域名部分。
$emailStruct = explode('@', $email);
-
替换
.为空字符串。
$username = str_replace($emailStruct[0],'.',''); //下标0为用户名部分,下标1为域名部分
-
删去
+后面的所有字符。
$usernameStruct = explode('+',$username);
$username = $usernameStruct[0];
这里用的是 explode
方法。
当然,也可以用 str_pos
获取 +
的位置,再用 strtr
函数截取字符串。
- 把用户名塞进记录用户名的数组里面。
$replacedEmails[] = $username.$emailStruct[1];
至此,对每个邮箱地址就处理完成了。
最后,用 foreach
包住以上代码,在 foreach
外面初始化 $replacedEmails
数组,用 array_unique
去重,再 count
该数组就完成了。
最终代码
class Solution {
function numUniqueEmails($emails) {
$replacedEmails = [];
foreach($emails as $email){
$emailStruct = explode('@',$email);
$username = str_replace($emailStruct[0],'.','');
$usernameStruct = explode('+',$username);
$username = $usernameStruct[0];
$replacedEmails[] = $username.$emailStruct[1];
}
return count(array_unique($replacedEmails));
}
}
优化方案
- 直接把用户名做为数组的键值,可以省略去重步骤。
若觉得本文章对你有用,欢迎用 爱发电 资助。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
注意力经济: 如何把大众的注意力变成生意
吴修铭 / 中信出版集团股份有限公司 / 2018-4-1 / 69
编辑推荐 这本书由万维钢作序,并在《得到》日课中多次推荐!中文版未上市之前,中文前沿媒体就在力推这本书!关于注意力争夺战的历史和现在,作者给了权威的梳理和定位! 百年来,在争夺注意力的战场上,媒体、广告、商人、企业和大众成为博弈的主角。商人是如何在注意力争夺战中获利的?媒体是如何在改变报道形式的?广告是如何进化的?以及,营销是如何变得随处可见、无孔不入的呢?这本书讲述了令商人或企业从吸......一起来看看 《注意力经济: 如何把大众的注意力变成生意》 这本书的介绍吧!