解题思路:

注意事项:

参考代码:

#include
#include
using namespace std;
int main()
{
int q = 0;
cin >> q;
char a[1000];
for(int i=0;i<q;i++)

{
cin >> a;
int l = strlen(a);
int x = 0, y = 0, z = 0, o = 0, sum = 0;
if (l >= 8 && l <= 16)
{
//统计字符类型
for (int i = 0; i < l; i++)
{
if (a[i] >= 'a' && a[i] <= 'z'  ) { x = 1; }
else if (a[i] >= 'A' && a[i] <= 'Z') { o = 1; }
else if (a[i] >= '0' && a[i] <= '9') { y = 1; }
else if (a[i]=='~'||a[i]=='!' || a[i] == '@' || a[i] == '#' || a[i] == '$' || a[i] ==  '%' || a[i] == '^') { z = 1; }
//这里不能直接else,因为逗号字符不行
}
sum = x + y + z+ o;
if (sum == 3) { cout << "YES" << endl; }
else { cout << "NO" << endl; }
}
else { cout << "NO" << endl; }
}
return 0;
}


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论