Leetcode PHP题解--D2 929. Unique Email Addresses

栏目: PHP · 发布时间: 5年前

内容简介:题目要求过滤重复的邮箱地址。最终返回不重复的用户名个数。过滤规则是:邮箱名中的

929. Unique Email Addresses

题目链接

929. Unique Email Addresses

题目分析

题目要求过滤重复的邮箱地址。最终返回不重复的用户名个数。

过滤规则是:邮箱名中的 . 要被忽略,且 + 后面的所有字符都要删去。域名部分则不进行处理。

思路

输入是一个数组,那么我们用 foreach 就可以了。

对于数组中的每一个元素,进行如下处理:

  1. 先以 @ 为分隔符拆分邮箱地址为用户名部分和域名部分。
$emailStruct = explode('@', $email);
  1. 替换 . 为空字符串。
$username = str_replace($emailStruct[0],'.',''); //下标0为用户名部分,下标1为域名部分
  1. 删去 + 后面的所有字符。
$usernameStruct = explode('+',$username);
$username = $usernameStruct[0];

这里用的是 explode 方法。

当然,也可以用 str_pos 获取 + 的位置,再用 strtr 函数截取字符串。

  1. 把用户名塞进记录用户名的数组里面。
$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));
    }
}

优化方案

  • 直接把用户名做为数组的键值,可以省略去重步骤。

若觉得本文章对你有用,欢迎用 爱发电 资助。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web开发敏捷之道

Web开发敏捷之道

Sam Ruby、Dave Thomas、David Heineme Hansson / 慕尼黑Isar工作组、骆古道 / 机械工业出版社 / 2012-3-15 / 59.00元

本书第1版曾荣获Jolt大奖“最佳技术图书”奖。在前3版的内容架构基础上,第4版增加了关于Rails中新特性和最佳实践的内容。本书从逐步创建一个真正的应用程序开始,然后介绍Rails的内置功能。全书分为3部分,第一部分介绍Rails的安装、应用程序验证、Rails框架的体系结构,以及Ruby语言的知识;第二部分用迭代方式创建应用程序,然后依据敏捷开发模式搭建测试案例,最终用Capistrano完成......一起来看看 《Web开发敏捷之道》 这本书的介绍吧!

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具