831.Masking Personal Information
831.Masking Personal Information
给你一条个人信息 string S,它可能是一个邮箱地址,也可能是一个电话号码。 我们将隐藏它的隐私信息,通过如下规则:
  1. 1.
    电子邮箱 定义名称 的长度大于2,并且只包含小写字母 a-z 和大写字母 A-Z。 电子邮箱地址由名称 开头,紧接着是符号 '@',后面接着一个名称 ,再接着一个点号 '.',然后是一个名称 。 电子邮箱地址确定为有效的,并且格式是"[email protected]"。 为了隐藏电子邮箱,所有的名称 必须被转换成小写的,并且第一个名称 的第一个字母和最后一个字母的中间的所有字母由 5 个 '*' 代替。
  2. 2.
    电话号码 电话号码是一串包括数组 0-9,以及 {'+', '-', '(', ')', ' '} 这几个字符的字符串。你可以假设电话号码包含 10 到 13 个数字。 电话号码的最后 10 个数字组成本地号码,在这之前的数字组成国际号码。注意,国际号码是可选的。我们只暴露最后 4 个数字并隐藏所有其他数字。 本地号码是有格式的,并且如 "--1111" 这样显示,这里的 1 表示暴露的数字。 为了隐藏有国际号码的电话号码,像 "+111 111 111 1111",我们以 "+--*-1111" 的格式来显示。在本地号码前面的 '+' 号和第一个 '-' 号仅当电话号码中包含国际号码时存在。例如,一个 12 位的电话号码应当以 "+-" 开头进行显示。 注意:像 "(",")"," " 这样的不相干的字符以及不符合上述格式的额外的减号或者加号都应当被删除。 最后,将提供的信息正确隐藏后返回。
1
示例 1:
2
4
输出: "l*****[email protected]"
5
解释:
6
所有的名称转换成小写, 第一个名称的第一个字符和最后一个字符中间由 5 个星号代替。
7
因此,"leetcode" -> "l*****e"。
8
示例 2:
9
10
11
输出: "a*****[email protected]"
12
解释:
13
第一个名称"ab"的第一个字符和最后一个字符的中间必须有 5 个星号
14
因此,"ab" -> "a*****b"。
15
示例 3:
16
17
输入: "1(234)567-890"
18
输出: "***-***-7890"
19
解释:
20
10 个数字的电话号码,那意味着所有的数字都是本地号码。
21
示例 4:
22
23
输入: "86-(10)12345678"
24
输出: "+**-***-***-5678"
25
解释:
26
12 位数字,2 个数字是国际号码另外 10 个数字是本地号码 。
27
注意:
28
29
S.length <= 40。
30
邮箱的长度至少是 8。
31
电话号码的长度至少是 10。
Copied!
方法:先判断是数字还是字母,一般从第一位开始判断,然后分别处理。
  • 对于数字,首先去除数字中的所有非数字符号,然后看数字长度,决定第一位用+和‘×’号数目。
  • 对于字母,用一个函数去转换小写,存储用户名的首位和末尾小写字符,其余全部转小写即可。
1
class Solution {
2
private:
3
char lower(char s)
4
{
5
if(s >= 'A' && s <='Z')
6
return s+32;
7
return s;
8
}
9
public:
10
string maskPII(string S) {
11
if((S[0]>='0' && S[0]<='9') ||S[0] =='+' || S[0] == '(')
12
{
13
for(int i=0;i<S.length();)
14
{
15
if(S[i]==' ' || S[i] == '-' || S[i] == '\(' || S[i]== '\)' || S[i] =='+')
16
S.erase(S.begin()+i);
17
else
18
i++;
19
}
20
int len=S.length();
21
string result;
22
if(len==10)
23
result="***-***-";
24
else if(len==11)
25
result="+*-***-***-";
26
else if(len ==12)
27
result="+**-***-***-";
28
else
29
result = "+***-***-***-";
30
result += S.substr(len-4,4);
31
return result;
32
}
33
else
34
{
35
int i=0;
36
int len=S.length();
37
string result;
38
result =lower(S[0]);
39
result += "*****";
40
while(i<len-1)
41
{
42
if(S[++i] == '@')
43
{
44
result += lower(S[i-1]) ;
45
break;
46
}
47
48
}
49
result += '@';
50
i++;
51
while(i<len)
52
{
53
if(S[i] == '.')
54
{
55
result += '.';
56
break;
57
}
58
result += lower(S[i]);
59
i++;
60
}
61
i++;
62
while(i<len)
63
{
64
result+=lower(S[i]);
65
i++;
66
}
67
return result;
68
69
}
70
}
71
};
Copied!
Copy link