解题思路:

注意事项:

参考代码:

#include<stdio.h>

#include<string.h>

#define N 51

int main()

{

    char a[N], c;

    int n, i;

    void pan(char a[]);

    scanf("%d%c", &n, &c);

    for(i = 0;i < n;i++){

    gets(a);

    if(strlen(a) > 16||strlen(a) < 8){

        printf("NO\n");

        continue;

    }

    pan(a);

    }

    return 0;

}

void pan(char a[]){

    char *p = a;

    int count[5] = {0}, i;

    while(*p != '\0'){

        if(*p >= 'A'&&*p <= 'Z')count[0] = 1;

        else if(*p >= 'a'&&*p <= 'z')count[1] = 1;

        else if(*p >= '0'&&*p <= '9')*(count+2) = 1;

        else if(*p =='~'||*p =='!'||*p =='#'||*p =='@'||*p =='%'||*p =='$'||*p =='^') count[3] = 1;

    p++;

    }

    for(i = 0;i < 4;i++)

        if(*(count+i) != 0)

            count[4]++;

    if(*(count+4) >= 3)printf("YES\n");

    else printf("NO\n");


}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论