[GESP202306 三级] 密码合规
题目描述
网站注册需要有用户名和密码,编写程序以检查用户输入密码的有效性。合规的密码应满足以下要求 :。
-
只能由 a ∼ z \texttt a \sim \texttt z a∼z 之间 26 26 26 个小写字母、 A ∼ Z \texttt A \sim \texttt Z A∼Z 之间 26 26 26 个大写字母、 0 ∼ 9 0 \sim 9 0∼9 之间 10 10 10 个数字以及
!@#$
四个特殊字符构成。 -
密码最短长度 : 6 :6 :6 个字符,密码最大长度 : 12 :12 :12 个字符。
-
大写字母,小写字母和数字必须至少有其中两种,以及至少有四个特殊字符中的一个。
输入格式
输入一行不含空格的字符串。约定长度不超过 100 100 100。该字符串被英文逗号分隔为多段,作为多组被检测密码。
输出格式
输出若干行,每行输出一组合规的密码。输出顺序以输入先后为序,即先输入则先输出。
样例 #1
样例输入 #1
seHJ12!@,sjdkffH$123,sdf!@&12HDHa!,123&^YUhg@!
样例输出 #1
seHJ12!@
sjdkffH$123
提示
【样例 1 解释】
输入被英文逗号分为了四组被检测密码:seHJ12!@
、sjdkffH$123
、sdf!@&12HDHa!
、123&^YUhg@!
。其中 sdf!@&12HDHa!
长度超过 12 个字符,不合规;123&^YUhg@!
包含四个特殊字符之外的字符不合规。
不是很难
#include <bits/stdc++.h>
using namespace std;
bool c(string t)//定义一个函数判断第一个条件
{
for(int i=0;i<t.size();i++)
{
if(t[i]>='a'&&t[i]<='z') return 1;
if(t[i]>='A'&&t[i]<='Z') return 1;
if(t[i]>='0'&&t[i]<='9') return 1;
if(t[i]=='!'||t[i]=='@'||t[i]=='#'||t[i]=='$') return 1;
return 0;
}
}
int main()
{
string s,t;
cin>>s;
s+=",";//这里防止最后一个密码后面没有逗号并且是合法的,如果不加的话,有时最后一个密码合法不会输出
for(int i=0;i<s.size();i++)
{
if(s[i]!=',') t+=s[i];//把每个密码都分隔出来
else
{
string g=t;t="";
if(g.size()<6||g.size()>12){continue;}//判断g字符串的长度
if(c(g)==0){continue;}
int a=0,b=0,c=0,d=0;
for(int i=0;i<g.size();i++)
{
if(g[i]>='a'&&g[i]<='z') a++;//把小写字母,大写字母,数字,特殊字符的个数记下来,为了判断第三个条件
if(g[i]>='A'&&g[i]<='Z') b++;
if(g[i]>='0'&&g[i]<='9') c++;
if(g[i]=='!'||g[i]=='@'||g[i]=='#'||g[i]=='$') d++;
}
if((a>0&&b>0||a>0&&c>0||b>0&&c>0)&&d>0) cout<<g<<endl;//这里判断第三个条件,如果满足,就输出g
}
}
return 0;
}```