1081 检查密码 (15分) C语言实现
程序员文章站
2022-06-12 19:27:59
...
本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母、数字和小数点 .,还必须既有字母也有数字。
输入格式:
输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行给出一个用户设置的密码,为不超过 80 个字符的非空字符串,以回车结束。
输出格式:
对每个用户的密码,在一行中输出系统反馈信息,分以下5种:
如果密码合法,输出Your password is wan mei.;
如果密码太短,不论合法与否,都输出Your password is tai duan le.;
如果密码长度合法,但存在不合法字符,则输出Your password is tai luan le.;
如果密码长度合法,但只有字母没有数字,则输出Your password needs shu zi.;
如果密码长度合法,但只有数字没有字母,则输出Your password needs zi mu.。
输入样例:
5
123s
zheshi.wodepw
1234.5678
WanMei23333
pass*word.6
输出样例:
Your password is tai duan le.
Your password needs shu zi.
Your password needs zi mu.
Your password is wan mei.
Your password is tai luan le.
分析
- 输入密码行数
- 输入密码
- 判断长度是否合法
- 判断是否存在不合法字符
- 判断是否既有数字又字母
源码
#include <stdio.h>
#include <string.h>
int main()
{
int N, digital=0, character = 0, length, flag;
char str[81];
scanf("%d", &N);
getchar();
for(int i=0; i< N; i++)
{
flag = 1;
//scanf("%s", str);
//getchar();
gets(str);
getchar();
length = strlen(str);
//printf("%d", length);
if(length < 6)
{
printf("Your password is tai duan le.\n");
continue;
}
digital=0;
character=0;
for(int j=0; j<length; j++)
{
if(str[j]>='0'&&str[j]<='9' || str[j]>='A'&&str[j]<='Z' || str[j]>='a' && str[j]<='z' || str[j] == '.')
{
if(str[j]>='0'&&str[j]<='9')
{
digital++;
}
if(str[j]>='A'&&str[j]<='Z' || str[j]>='a' && str[j]<='z')
{
character++;
}
}
else
{
printf("Your password is tai luan le.\n");
flag = 0;
break;
}
}
if(flag == 1 && digital == 0)
{
printf("Your password needs shu zi.\n");
}
else if(flag == 1 && character == 0)
{
printf("Your password needs zi mu.\n");
}
else if(flag == 1 && digital>0 && character > 0)
{
printf("Your password is wan mei.\n");
}
}
return 0;
}
小结
这道题有个坑,大坑。就是空格。输入时是可以输入空格的,只不过是当做非法字符处理。所以就不能用scanf("%s")了,要用gets(),并且要用getchar屏蔽掉回车
然后加上空格的判断后,原来测试点3是正确的,现在不正确了,也没搞明白,后面在看看。
要是大佬看出问题所在,请赐教,十分感谢。
参考资料
- 空格的坑
https://blog.csdn.net/sunshine_0880/article/details/82466696?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.compare&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.compare