LeetCode.每日一题 831. 隐藏个人信息

 

Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法......感兴趣就关注我吧!你定不会失望。

个人主页:主页链接

算法专栏:专栏链接

     我会一直往里填充内容哒!

LeetCode专栏:专栏链接 

    目前在刷初级算法的LeetBook 。若每日一题当中有力所能及的题目,也会当天做完发出

代码仓库:Gitee链接

点击关注=收获更多优质内容

目录

题目: 831. 隐藏个人信息

题解:

代码实现:

完结撒花

 

题目: 831. 隐藏个人信息

LeetCode.每日一题 831. 隐藏个人信息_第1张图片

LeetCode.每日一题 831. 隐藏个人信息_第2张图片

题解:

这题的题目非常的长,但也有好处,一眼就看出来是模拟题。模拟题一般都不会很难,这里我们来看看具体是怎么做的。

先来分析下题目,大概有两种情况.

第一种是邮箱,相对来说比较简单

LeetCode.每日一题 831. 隐藏个人信息_第3张图片

将所有字符转换成小写字母,之后再将第一个字符到域名前的两个字符转换成*****.即可

那么我们来看看如何判断这种情况呢?

邮箱中一定含有@这个符号,所以我们find一下就可以了,如果有则说明是邮箱.

(注意,若没有find到 则返回的是::nopos,据此来判断即可)

所以若为邮箱,我们先使用(transform函数)

其定义为

 transform(first.begin(),first.end(),second.begin(),op);

前两个参数为:检测范围,第三个参数为把转换后的结果存入的目标容器,最后一个参数为操作符 

将所有字母转换为小写字母后,直接返回,第一个字符加上五个*,再加上@的前一个字符到最后即可.

return s.substr(0,1)+"*****"+s.substr(at-1);

注:substr的(src,length)含义为:从目标点开始选取length的字符

                  (src)从src到结尾的字符 

 第二种是电话号码,相对来说比较困难了

LeetCode.每日一题 831. 隐藏个人信息_第4张图片

 第一步将所有的符号去掉,这里采用正则表达式的方法.

 s=regex_replace(s,regex("[^0-9]"),"");

 regex_replace为正则表达式里的替换函数,需要包含头文件.

其三个参数为:src原地址,正则表达式,替换为.

所以这里的意思是将所有0-9数字以外的字符替换成 "",也就是删除,(^表示取反),之后存入s当中

 return country[s.size()-10]+"***-***-"+s.substr(s.size()-4);

因为题目规定了,手机号为10位,所以国家号的长度即为size-10

至此即可做完本题

(过几天我会更新一下c++用正则表达式的博客,可以关注下) 

模拟题虽然没有很算法,但我觉得对于学习函数还是很有意义的! 

代码实现:

class Solution {
    vectorcountry={"","+*-","+**-","+***-"};
public:
    string maskPII(string s) {
        string res;
       auto at= s.find("@");
       if(at != string::npos)
       {
        transform(s.begin(),s.end(),s.begin(),::tolower);
        return s.substr(0,1)+"*****"+s.substr(at-1);
       }

            s=regex_replace(s,regex("[^0-9]"),"");
            return country[s.size()-10]+"***-***-"+s.substr(s.size()-4);

    }
};

 

完结撒花:

本篇博客的内容【LeetCode.每日一题 831. 隐藏个人信息】已经结束。

若对你有些许帮助,可以点赞、关注、评论支持下博主,你的支持将是我前进路上最大的动力。

若以上内容有任何问题,欢迎在评论区指出。若对以上内容有任何不解,都可私信评论询问。

诸君,山顶见!

你可能感兴趣的:(年薪百万必看算法,小菜鸡的LeetCode之路,leetcode,算法,职场和发展)