zoukankan      html  css  js  c++  java
  • B1081 检查密码 (15分)

    B1081 检查密码 (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.
    

    思考

    如果密码合法,输出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.。

    【PAT】B1081 检查密码(15 分) - 路明天 - 博客园 https://www.cnblogs.com/hebust/p/9490291.html

    		char temp[100];
    		scanf("%[^
    ]",temp);
            judge(temp);
            getchar();
    

    就这里不一样,对一行字符串的读取的处理。

    【扩展知识1】scanf("%[^n],c)和scanf("%[^ ],c)具体含义 - Learn coding :Dream it, Code it - CSDN博客 https://blog.csdn.net/mirrorsbeyourself/article/details/41204699

    写的很详细了,这就跟参考文献一样。

    综合上述,我们可以知道%[^ ]%[^ ]的含义了。符号^ 表示取反的意思。[^ ]表示除了空格,所有的字符都可以读取;[^ ]则表示除了换行符,所有的字符都可以读取。
    有时候,在程序中需要读取字符串直到回车为止,也可以使用函数gets(array)读取。

    那么问题来了,我的判断也是基于,无空格的字符串处理来编写的函数,所以这里改了以后就要大改。
    注意“Hello”是一种字符串,无空格的。
    “Hello World!”是另一种字符串,中间有空格的。

    别人的AC代码

    #include<cstdio>
    #include<string.h>
    #include<ctype.h>
    #include<algorithm>
    using namespace std;
    bool jud(char a){
        if(isdigit(a)||islower(a)||isupper(a)||a=='.')return true;
        else return false;
    }
    void judge(char *arr){
        int len=strlen(arr);
        if(len<6){
            printf("Your password is tai duan le.
    ");
            return;
        }
        int ying=0,dig=0,dot=0;
        for(int i=0;i<len;i++){
            if(jud(arr[i])==false){
                printf("Your password is tai luan le.
    ");return;
            }
            if(isdigit(arr[i])) dig++;
            if(islower(arr[i])||isupper(arr[i])) ying++;
        }
        if(ying==0) printf("Your password needs zi mu.
    ");
        else if(dig==0) printf("Your password needs shu zi.
    ");
        else printf("Your password is wan mei.
    ");
    }
    int main(){
        int N;scanf("%d",&N);
        getchar();
        for(int i=0;i<N;i++){
            char temp[100];
            scanf("%[^
    ]",temp);
            judge(temp);
            getchar();
        }
        return 0;
    }
    

    我的AC代码

    注释处就是针对性的修改的部分。

    #include<bits/stdc++.h>
    using namespace std;
    int hefa(char s[],int len){
    	int num_digi=0,num_al=0;
    	for(int i=0;i<len;i++){
    		if(!isalnum(s[i]) && s[i]!='.')
    			return 1;
    		if(isdigit(s[i]))
    			num_digi++;
    		if(isalpha(s[i]))
    			num_al++;
    	}
    	if(num_digi==0)
    		return 2;
    	if(num_al==0)
    		return 3;
    	return 0;	
    }
    int main(void){
    	int n,len,flag;
    	char tmp[81];
    	scanf("%d",&n);
    	for(int i=0;i<n;i++){
    		getchar();//为了吸收掉读入的回车符
    		//scanf("%s", tmp);//这里读到空格为止,可是又一个样例过不去,那就是包含空格的字符串 
    		scanf("%[^
    ]",tmp);
    		len = strlen(tmp);// strlen函数遇到`''`才会结束,所以没问题 
    		if(len<6){
    			printf("Your password is tai duan le.
    ");
    			continue;
    		}
    		flag = hefa(tmp,len);
    		if(flag==1){
    			printf("Your password is tai luan le.
    ");
    		}
    		else if(flag==2){
    			printf("Your password needs shu zi.
    ");
    		}
    		else if(flag==3){
    			printf("Your password needs zi mu.
    ");
    		}
    		else
    			printf("Your password is wan mei.
    ");
    		
    	}
    	return 0;
    }
    
  • 相关阅读:
    写了一个html5音乐播放器
    跨站脚本攻击之反射型XSS漏洞
    org.hibernate.ObjectNotFoundException异常一则
    addEventListener第二个参数的handleEvent
    IE的fireEvent方法
    DexMongoDB索引优化工具
    javascript 位运算符
    javascript contains方法来判断元素包含关系
    将uglifyjs添加到鼠标右键菜单
    过滤XSS(跨站脚本攻击)的函数和防止svn版本库被浏览
  • 原文地址:https://www.cnblogs.com/lingr7/p/10295152.html
Copyright © 2011-2022 走看看