解题思路:
先输入密码,(循环),然后判断每组密码便可
注意事项:
浅色全为我检验程序所用
参考代码:
#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int main()
{
int b,m,i,j,num1,num2,num3,num4,num5,sum=0;
cin>>m;
int a[m];
char c[m][50]; // m个密码,每个密码长度不大于50
for(i=0;i<m;i++)
{
cin>>c[i];
a[i]=strlen(c[i]); // //记录每个密码长度
//cout<<a[i]<<" ";
}
for(i=0;i<m;i++) //因为以3种及以上为合格,所以自然想到每一种形式出现记录为1
{ //只需把每种情况下num的值与3比较便可
num1=0,num2=0,num3=0,num4=0,num5=0; //每次大循环,意味着每天密码,重新开始,所以赋初值
if(a[i]<8&&a[i]<=16) //如果不满足长度条件直接输出No,开始下一个循环
{
cout<<"NO"<<endl;
continue;
}
for(j=0;c[i][j]!='\0';j++)
{
if('A'<=c[i][j]&&c[i][j]<='Z')
{
num1=1;
}
else if('a'<=c[i][j]&&c[i][j]<='z')
{
num2=1;
}
else if('0'<=c[i][j]&&c[i][j]<='9')
{
num3=1;
}
else if(c[i][j]=='!'||c[i][j]=='~'||c[i][j]=='@'||c[i][j]=='#'||c[i][j]=='$'||c[i][j]=='%'||c[i][j]=='^')
{num4=1;} //起初我以为剩余的字符就是特殊字符...然后错啦,所以单独列出
else //剩余字符皆是不满足要求的,只要num5==1,视为非安全密码
{num5=1;}
}
sum=num1+num2+num3+num4;
//cout<<sum<<" "<<num1<<num2<<num3<<num4<<num5<<endl;
if(sum>=3&&(num5!=1)) //&&(8<=a[i]&&a[i]<=16)
{
cout<<"YES"<<endl;
}
else
cout<<"NO"<<endl;
}
}
0.0分
0 人评分
打水问题 (C语言代码)浏览:1070 |
C语言程序设计教程(第三版)课后习题7.1 (C语言代码)浏览:1222 |
wu-理财计划 (C++代码)浏览:827 |
用筛法求之N内的素数。 (C语言代码)浏览:646 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:598 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:520 |
Hello, world! (C语言代码)浏览:714 |
A+B for Input-Output Practice (V) (C语言代码)浏览:459 |
2006年春浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:661 |
筛排处理 (C语言代码)浏览:782 |
Spperman 2018-05-15 21:57:24 |
c++是可以的,c好像不行.