PAT乙级1081 检查密码(C语言)

1081 检查密码 (15 分)

本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于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,i,j,count1,count2,count3,count4;//count分别用来统计大写字母,小写字母,小数点,数字 
	char c;
	scanf("%d",&N);
	getchar();
	char arr[N][80];
	int a[N];
	for(i=0;i<N;i++)
	{
		count1=count2=count3=count4=0;//每一行字符检测完后需要重置为0 
		gets(arr[i]);
		if(strlen(arr[i])<6)
			{
				a[i]=2;
				continue;
			}
		for(j=0;j<strlen(arr[i]);j++)
		{
			c=arr[i][j];
			if(c>64&&c<91)//检测到大写字母,count1自增 
				count1++;
			if(c>96&&c<123)//检测到小写字母,count2自增 
				count2++;
			if(c==46)//检测到小数点,count3自增 
				count3++;
			if(c>47&&c<58)//检测到数字,count4自增 
				count4++;
		}
		if(count1+count2+count3+count4!=strlen(arr[i]))	//4个之和不等于数组长度,说明出现了其他字符 
			{a[i]=3;continue;}
		if(count4==0)//count4为0,说明无数字 
			{a[i]=4;continue;}
		if(count1+count2==0)//count1+count2为0,说明无字母 
			{a[i]=5;continue;}
		a[i]=1;
	}
	for(i=0;i<N;i++)
	{
		switch(a[i])
		{
			case 1:printf("Your password is wan mei.");break;
			case 2:printf("Your password is tai duan le.");break;
			case 3:printf("Your password is tai luan le.");break;
			case 4:printf("Your password needs shu zi.");break;
			case 5:printf("Your password needs zi mu.");break;
		}	
		printf("\n");
	}
	return 0;
} 

运行结果
在这里插入图片描述
个人体会
我的思路普通简单,先判断字符串长度是否合理,需注意是否有空格、TAB之类的,因此用gets输入。然后遍历检测各位的类型,统计次数,分析情况,存储输出,最后遍历打印输出。
scanf()和gets()的区别:
scanf函数以空格、Tab键或回车键作为输入字符串时的分隔符或结束符,所以空格、Tab键不能出现在字符串中;而利用gets函数输入字符串时没有此限制,所以在检查密码合法性担心会出现空格的非法字符,所以应该用gets函数。在接收完N后要getchar()读取一下换行符才能用gets,否则换行符会被读进gets中。

猜你喜欢

转载自blog.csdn.net/qq_40902753/article/details/89048523