2023-04-01每日一题
一、题目编号
831. 隐藏个人信息
二、题目链接
https://leetcode.cn/problems/masking-personal-information/
三、题目描述
给你一条个人信息字符串 s ,可能表示一个 邮箱地址 ,也可能表示一串 电话号码 。返回按如下规则 隐藏 个人信息后的结果:
电子邮件地址:
一个电子邮件地址由以下部分组成:
一个 名字 ,由大小写英文字母组成,后面跟着
一个 ‘@’ 字符,后面跟着
一个 域名 ,由大小写英文字母和一个位于中间的 ‘.’ 字符组成。‘.’ 不会是域名的第一个或者最后一个字符。
要想隐藏电子邮件地址中的个人信息:
名字 和 域名 部分的大写英文字母应当转换成小写英文字母。
名字 中间的字母(即,除第一个和最后一个字母外)必须用 5 个 “*****” 替换。
电话号码:
一个电话号码应当按下述格式组成:
电话号码可以由 10-13 位数字组成
后 10 位构成 本地号码
前面剩下的 0-3 位,构成 国家代码
利用 {‘+’, ‘-’, ‘(’, ‘)’, ’ '} 这些 分隔字符 按某种形式对上述数字进行分隔
要想隐藏电话号码中的个人信息:
移除所有 分隔字符
隐藏个人信息后的电话号码应该遵从这种格式:
“--XXXX” 如果国家代码为 0 位数字
“+---XXXX" 如果国家代码为 1 位数字
"+---XXXX" 如果国家代码为 2 位数字
"+--**-XXXX” 如果国家代码为 3 位数字
“XXXX” 是最后 4 位 本地号码
四、解题代码
class Solution {
bool is_telephone_number(string s){
for(int i = 0; i < s.size(); ++i){
if(s[i] == '@'){
return false;
}
}
return true;
}
char change(char &ch){
if(ch >= 'A' && ch <= 'Z'){
ch = ch - 'A' + 'a';
}
return ch;
}
public:
string maskPII(string s) {
string res;
if(is_telephone_number(s) == true){
string num;
for(int i = 0; i < s.size(); ++i){
if(s[i] >= '0' && s[i] <= '9'){
num += s[i];
}
}
s = num;
if(s.size() == 10){
res += "***-***-";
res += s[6];
res += s[7];
res += s[8];
res += s[9];
} else if(s.size() == 11){
res += "+*-***-***-";
res += s[7];
res += s[8];
res += s[9];
res += s[10];
} else if(s.size() == 12){
res += "+**-***-***-";
res += s[8];
res += s[9];
res += s[10];
res += s[11];
} else if(s.size() == 13){
res += "+***-***-***-";
res += s[9];
res += s[10];
res += s[11];
res += s[12];
}
} else{
string name;
string realm_name;
int flag = 0;
for(int i = 0; i < s.size(); ++i){
if(s[i] != '@' && flag == 0){
name += change(s[i]);
} else if(s[i] == '@'){
flag = 1;
continue;
} else if(flag == 1){
realm_name += change(s[i]);
}
}
int n = name.size()-1;
res += name[0];
res += "*****";
res += name[n];
res += "@";
res += realm_name;
}
return res;
}
};
五、解题思路
(1) 首先我们要区分字符串是代表的是电子邮箱地址还是电话号码。我们通过判断字符串中是否存在‘@’来判断。如果存在则是电子邮箱地址,如果是电话号码则不存在。
(2)接着我们分类讨论,分别模拟,如果是电子邮箱地址,我们将名字和域名分开用字符串表示,并且同时将大写字母转化为小写字母。只需要按照题目中的要求重新组合起来即可。如果是电话号码的话,我们先将电话号码中的分隔符去掉,然后按照电话号码的位数,根据题目的要求进行隐藏即可。
(3)最后输出我们的结果即可得到正确答案。