831 隐藏个人信息

题目描述:
给你一条个人信息字符串 S,它可能是一个 邮箱地址 ,也可能是一串 电话号码 。
我们将隐藏它的隐私信息,通过如下规则:

  1. 电子邮箱
    定义名称 name 是长度大于等于 2 (length ≥ 2),并且只包含小写字母 a-z 和大写字母 A-Z 的字符串。

电子邮箱地址由名称 name 开头,紧接着是符号 ‘@’,后面接着一个名称 name,再接着一个点号 ‘.’,然后是一个名称 name。

电子邮箱地址确定为有效的,并且格式是 “[email protected]”。

为了隐藏电子邮箱,所有的名称 name 必须被转换成小写的,并且第一个名称 name 的第一个字母和最后一个字母的中间的所有字母由 5 个 ‘*’ 代替。

  1. 电话号码

电话号码是一串包括数字 0-9,以及 {’+’, ‘-’, ‘(’, ‘)’, ’ '} 这几个字符的字符串。你可以假设电话号码包含 10 到 13 个数字。

电话号码的最后 10 个数字组成本地号码,在这之前的数字组成国际号码。注意,国际号码是可选的。我们只暴露最后 4 个数字并隐藏所有其他数字。

本地号码是有格式的,并且如 “***-***-1111” 这样显示,这里的 1 表示暴露的数字。

为了隐藏有国际号码的电话号码,像 “+111 111 111 1111”,我们以 “+***-***-*-1111" 的格式来显示。在本地号码前面的 ‘+’ 号和第一个 ‘-’ 号仅当电话号码中包含国际号码时存在。例如,一个 12 位的电话号码应当以 "+-” 开头进行显示。

注意:像 “(”,")"," " 这样的不相干的字符以及不符合上述格式的额外的减号或者加号都应当被删除。

最后,将提供的信息正确隐藏后返回。

示例 1:
输入: “[email protected]
输出: “l[email protected]"
解释:
所有的名称转换成小写, 第一个名称的第一个字符和最后一个字符中间由 5 个星号代替。
因此,“leetcode” -> "l
e”。

示例 2:
输入: “[email protected]
输出: “a[email protected]"
解释:
第一个名称"ab"的第一个字符和最后一个字符的中间必须有 5 个星号
因此,“ab” -> "a
b”。

示例 3:
输入: “1(234)567-890”
输出: “***-***-7890”
解释:
10 个数字的电话号码,那意味着所有的数字都是本地号码。

示例 4:
输入: “86-(10)12345678”
输出: “+-*-***-5678”
解释:
12 位数字,2 个数字是国际号码另外 10 个数字是本地号码 。

注意:
S.length <= 40。
邮箱的长度至少是 8。
电话号码的长度至少是 10。

方法1:
主要思路:解题链接汇总
(1)直接模拟题意即可;

class Solution {
    
    
public:
    string phone(string&s){
    
    
        string tmp;//先将数字提取出来
        for(char&ch:s){
    
    
            if(ch>='0'&&ch<='9'){
    
    
                tmp+=ch;
            }
        }
        string res;
        //根据数字的长度,直接生成对应的字符串
        if(tmp.size()>10){
    
    
            string str=string(tmp.size()-10,'*');
            res="+"+str+"-***-***-"+tmp.substr(tmp.size()-4,4);
        }
        else{
    
    
            res="***-***-"+tmp.substr(tmp.size()-4,4);
        }
        return res;
    }
    string email(string&s){
    
    
        string res;
        vector<string> strs;
        //将三个名字转为对应的小写,并存储
        for(int i=0;i<s.size();++i){
    
    
            string str;
            while(i<s.size()&&s[i]!='@'&&s[i]!='.'){
    
    
                if(s[i]>='A'&&s[i]<='Z'){
    
    
                    str+=s[i]+'a'-'A';
                }
                else{
    
    
                    str+=s[i];
                }
                ++i;
            }
            if(strs.empty()){
    
    //第一个名字
                strs.push_back("");
                strs[0]+=str[0];
                strs[0]+="*****";
                strs[0]+=str.back();
            }
            else{
    
    //后两个名字
                strs.push_back(str);
            }
        }
        //返回字符串
        return strs[0]+"@"+strs[1]+"."+strs[2];
    }
    string maskPII(string S) {
    
    
    	//判断当前字符串是邮箱还是电话,调用对应的函数
        if((S[0]>='A'&&S[0]<='Z')||(S[0]>='a'&&S[0]<='z')){
    
    
            return email(S);
        }
        return phone(S);
    }
};

猜你喜欢

转载自blog.csdn.net/weixin_44171872/article/details/114465157