1. #include<stdio.h>
  2. #include<string.h>
  3. int judge(char *mima,char *A,char *B,char *C,char *D);
  4. int main(){
  5. char A[26];
  6. char B[26];
  7. char C[10];
  8. char D[7]={'~','!','@','#','$','%','^'};
  9. int daxie = 65;
  10. int xiaoxie = 97;
  11. int shuzi = 48;
  12. for(int i=0; i<26; i++,shuzi++,daxie++,xiaoxie++){
  13. A[i] = daxie;
  14. B[i] = xiaoxie;
  15. if(i<10){
  16. C[i]=shuzi;
  17. }
  18. }
  19. int n;
  20. scanf("%d\n",&n);
  21. char mima[50];
  22. for(int i=0; i<n; i++){
  23. gets(mima);
  24. if(strlen(mima)>=8&&strlen(mima)<=16&&judge(mima,A,B,C,D)>=3){
  25. printf("YES\n");
  26. }else{
  27. printf("NO\n");
  28. }
  29. }
  30. }
  31. int judge(char *mima,char *A, char *B,char *C,char *D){
  32. int k = 0;
  33. int flag[4]={1,1,1,1};
  34. for(int i=0; i<strlen(mima); i++){
  35. if(flag[0]==1){
  36. for(int j=0; j<26; j++){
  37. if(mima[i]==A[j]){
  38. k++;
  39. flag[0]=0;
  40. break;
  41. }
  42. }
  43. }
  44. if(flag[1]==1){
  45. for(int j=0; j<26; j++){
  46. if(mima[i]==B[j]){
  47. k++;
  48. flag[1]=0;
  49. break;
  50. }
  51. }
  52. }
  53. if(flag[2]==1){
  54. for(int j=0; j<10; j++){
  55. if(mima[i]==C[j]){
  56. k++;
  57. flag[2]=0;
  58. break;
  59. }
  60. }
  61. }
  62. if(flag[3]==1){
  63. for(int j=0; j<7; j++){
  64. if(mima[i]==D[j]){
  65. k++;
  66. flag[3]=0;
  67. break;
  68. }
  69. }
  70. }
  71. }
  72. return k;
  73. }
点赞(0)
 

0 分

0 人评分

 

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论