12.27学习总结

问题 G: 密码(JSU-ZJJ)

题目描述

网上流传一句话:"常在网上飘啊,哪能不挨刀啊~"。其实要想能安安心心地上网其实也不难,学点安全知识就可以。

首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件:

(1).密码长度大于等于8,且不要超过16。
(2).密码中的字符应该来自下面“字符类别”中四组中的至少三组。

这四个字符类别分别为:
1.大写字母:A,B,C...Z;
2.小写字母:a,b,c...z;
3.数字:0,1,2...9;
4.特殊符号:~,!,@,#,$,%,^,&;

给你一个密码,你的任务就是判断它是不是一个安全的密码。

输入

输入数据第一行包含一个数M,接下有M行,每行一个密码(长度最大可能为50),密码仅包括上面的四类字符。

输出

对于每个测试实例,判断这个密码是不是一个安全的密码,是的话输出YES,否则输出NO。

样例输入 复制

3
a1b2c3d4
Linle@ACM
^~^@^@!%

样例输出 复制

NO
YES
NO

题解:

#include <stdio.h>
#include <string.h>
int main()
{
	int m,i;scanf("%d",&m);getchar();
	char str[50];
	for(i=0;i<m;i++){	
	scanf("%[^\n]%*c",str);
	int k=strlen(str);
	int ant=0,bnt=0,ent=0,dnt=0,cnt=0;
	if(k>=8&&k<=16){
	for(int j=0;j<k;j++)
	{   
		if(str[j]>='A'&&str[j]<='Z')ant=1;	
		 if(str[j]>='a'&&str[j]<='z')bnt=1;	
		 if(str[j]>='0'&&str[j]<='9')dnt=1;	
		if( str[j]=='~' || str[j]=='!' || str[j]=='@' || str[j]=='#' || str[j]=='$' || str[j]=='%' || str[j]=='^' ) ent=1;	
		cnt=ant+bnt+ent+dnt;	
	}
	if(cnt>=3)printf("YES\n");
	else printf("NO\n");
	}else printf("NO\n");
	}
	return 0;
}

今天复习了几个字符串函数的用法

笔记:

putchar():输出一个字符,返回字符输出个数,EOF(-1)表示写失败。

getchar():  从输入读入一个字符,返回EOF。

strlen():  计算字符数组从第一个字符到'\0'之间的字符长度

strcmp():  比较两个字符串大小,第一个大于第二个输出1;小于输出-1;等于输出0。

strcpy():  把第二个参数字符串拷贝到第一个中。

strcat():  把第二个参数拷贝到第一个的后面结成一个长字符串。

因为拷贝的字符串长度不确定,最后两个函数的使用是不稳定的。还可以用

char *strncpy(char *restrict dst,const char *restrict src,size_t n)

char *strncat(char *restrict s1,const char *restrict s2,size_t n)

n:最多拷贝长度。还有

int strncmp(const char *s1,const char *s2,size_t n)

这种形式的字符串比较函数可以比较两字符串中长度为n的字符串段的大小。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值