当前位置:   article > 正文

隐藏个人信息c++/c_info是一条代表个人信息的字符串,可能 力扣

info是一条代表个人信息的字符串,可能 力扣

给你一条个人信息字符串 s ,可能表示一个 邮箱地址 ,也可能表示一串 电话号码 。返回按如下规则 隐藏 个人信息后的结果:

电子邮件地址:

一个电子邮件地址由以下部分组成:

一个 名字 ,由大小写英文字母组成,后面跟着 一个 ‘@’ 字符,后面跟着 一个 域名 ,由大小写英文字母和一个位于中间的 ‘.’
字符组成。’.’ 不会是域名的第一个或者最后一个字符。 要想隐藏电子邮件地址中的个人信息:

名字 和 域名 部分的大写英文字母应当转换成小写英文字母。 名字 中间的字母(即,除第一个和最后一个字母外)必须用 5 个 “*****”
替换。 电话号码:

一个电话号码应当按下述格式组成:

电话号码可以由 10-13 位数字组成 后 10 位构成 本地号码 前面剩下的 0-3 位,构成 国家代码 利用 {’+’, ‘-’,
‘(’, ‘)’, ’ '} 这些 分隔字符 按某种形式对上述数字进行分隔 要想隐藏电话号码中的个人信息:

移除所有 分隔字符 隐藏个人信息后的电话号码应该遵从这种格式: “***-**-XXXX" 如果国家代码为 0 位数字
"+
-***-*-XXXX" 如果国家代码为 1 位数字 "+-***-***-XXXX” 如果国家代码为 2 位数字
“+***-***-***-XXXX” 如果国家代码为 3 位数字 “XXXX” 是最后 4 位 本地号码 示例 1:

输入:s = “LeetCode@LeetCode.com” 输出:“l*****e@leetcode.com” 解释:s
是一个电子邮件地址。 名字和域名都转换为小写,名字的中间用 5 个 * 替换。 示例 2:

输入:s = “AB@qq.com” 输出:“a*****b@qq.com” 解释:s 是一个电子邮件地址。
名字和域名都转换为小写,名字的中间用 5 个 * 替换。 注意,尽管 “ab” 只有两个字符,但中间仍然必须有 5 个 * 。 示例 3:

输入:s = “1(234)567-890” 输出:"***-***-7890" 解释:s 是一个电话号码。 共计 10
位数字,所以本地号码为 10 位数字,国家代码为 0 位数字。 因此,隐藏后的电话号码应该是 “***-***-7890” 。 示例 4:

输入:s = “86-(10)12345678” 输出:"+-*-*-5678" 解释:s 是一个电话号码。 共计 12
位数字,所以本地号码为 10 位数字,国家代码为 2 位数字。 因此,隐藏后的电话号码应该是 "+
-***-***-7890" 。

提示:

s 是一个 有效 的电子邮件或者电话号码 如果 s 是一个电子邮件: 8 <= s.length <= 40 s
是由大小写英文字母,恰好一个 ‘@’ 字符,以及 ‘.’ 字符组成 如果 s 是一个电话号码: 10 <= s.length <= 20 s
是由数字、空格、字符 ‘(’、’)’、’-’ 和 ‘+’ 组成

其实这个题不难,只是效率高的方法难想。只需要按部就班的写代码就可以了,没有什么逻辑上的难点。

代码

class Solution {
public:
    string maskPII(string s) {
        //首先判断是邮箱还是电话
	char first = s[0];

	string res = "";
	if (!((first >= 'a' && first <= 'z') || (first >= 'A' && first <= 'Z'))) {//不是字母
		//电话
		//先判断国家代码是几位
		int k = 0;
		int n = 0;
		for (int i = s.length()-1; i >= 0; i--) {
			if (s[i] != '-' && s[i] != '(' && s[i] != ')' && s[i] != ' '&& s[i] != '+') {
				n++;
				if (n > 10) {
					k++;//k等于几,就是几位
				}
			}
		}
		
		if (k == 1) {
			res += "+*-";
		}
		else if (k == 2) {
			res += "+**-";
		}
		else if (k == 3) {
			res += "+***-";
		}

		res += "***-***-";//统一的

		//然后将s舍去国家代码
		s = s.substr(k + 1);
		cout << s << endl;
		//然后从后向前,找到最后4个数字
		string num = "";
		int m = 0;
		for (int i = s.length() - 1; i >= 0; i--) {
			if (s[i] != ')' && s[i] != '(' && s[i] != '-' && s[i] != ' ') {//然后从后向前,找到最后4个数字
				num = s[i] + num;
				m++;
				if (m == 4)break;
			}
		}
		res += num;
	}
	else {
		//邮箱
		int email = s.find("@");
		string name = s.substr(0, email);
		string address = s.substr(email + 1);
		//字符大写转小写
		if (name[0] >= 'A' && name[0] <= 'Z') {
			name[0] = tolower(name[0]);
		}
		res += name[0];
		res += "*****";
		if (name[name.length() - 1] >= 'A' && name[name.length() - 1] <= 'Z') {
			name[name.length() - 1] = tolower(name[name.length() - 1]);
		}
		res += name[name.length() - 1];
		res += "@";
		for (int i = 0; i < address.length(); i++) {
			if (address[i] >= 'A' && address[i] <= 'Z') {
				address[i] = tolower(address[i]);
			}
		}
		res += address;
	}
	return res;
    }
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74

其中,res += name[0];以及res += “";两句代码,不可以写成res+=name[0]+ "”;这样会报错,我也不知道为什么。
在char类型,比如char s;(s-‘0’)会是一个数字,就算s是一个符号,(s-‘0’)也会是一个数字。
昨天因为一些事情,前前后后打了5个半小时电话。
一个集坚强与自信于一身的菇凉。

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号