密码合规检测-GESP202306三级题二

密码合规检测

【问题描述】

网站注册需要有用户名和密码,编写程序以检查用户输入密码的有效性。合规的密码应满足以下要求:

1、只能由 a-z 之间 26 个小写字母、A-Z 之间 26 个大写字母、0-9 之间 10个数字以及!@#$四个特殊字符构成。

2、密码最短长度:6 个字符,密码最大长度:12 个字符。

3、大写字母、小写字母和数字必须至少有其中两种,以及至少有四个特殊字符中的一个。

【输入描述】

输入一行不含空格的字符串。约定长度不超过 100。该字符串被英文逗号分隔为多段,作为多组被检测密码。

【输出描述】

输出若干行,每行输出一组合规的密码。

输出顺序以输入先后为序,即先输入则先输出。

【样例输入 1】

seHJ12!@,sjdkffH$123,sdf!@&12HDHa!,123&^YUhg@!

【样例输出 1】

seHJ12!@

sjdkffH$123

【样例解释 1】

输入被英文逗号分为了四组被检测密码:“seHJ12!@”、“sjdkffH$123”、“sdf!@&12HDHa!”、“123&^YUhg@!”。其中,“sdf!@&12HDHa!”长度超过 12个字符,不合规;“123&^YUhg@!”包含四个特殊字符之外的字符“^”,不合规。

 代码如下,提示答案错误,不知道有什么情况没考虑到。

 #include"bits/stdc++.h"
using namespace std;
bool mima(char s1[]){
    int t=0,xiao=0,da=0,zi=0;
    for(int i=0;s1[i]!='\0';i++){
        if(s1[i]>='a'&&s1[i]<='z')
            xiao=1;
        else if(s1[i]>='A'&&s1[i]<='Z')
            da=1;
        else if(s1[i]>='0'&&s1[i]<='9')
            zi=1;
        else if(s1[i]=='!'||s1[i]=='@'||s1[i]=='#'||s1[i]=='$')
            t=1;
        else
            return 0;
                    
        if(s1[i+1]=='\0'){
            if(i+1<6||i+1>12){
                return 0;
            }
            if(xiao+da+zi>=2&&t==1)
                return 1;
            else return 0;
        }
    }
}
int main(){
    char s[1500],s1[1100];
    gets(s);
    int begin=0;
    for(int i=0;s[i]!='\0';i++){
        if(s[i]==','||s[i+1]=='\0'){
            if(s[i+1]=='\0'){
                s1[i-begin]=s[i];
                s1[i-begin+1]='\0';
            }
            else s1[i-begin]='\0';
            //cout<<s1<<endl;
            if(mima(s1)==1){
                cout<<s1<<endl; 
            }
            begin=i+1;
        }
        else 
        s1[i-begin]=s[i];
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
图像压缩是一种通过减少图像的数据量来实现图像文件大小的减小的技术。在图像压缩中,主要使用了两种方法:有损压缩和无损压缩。 有损压缩是指压缩过程中会舍弃一些不太重要的图像细节,以减小文件大小。最常用的有损压缩算法是JPEG(Joint Photographic Experts Group)算法。JPEG算法使用了离散余弦变换(DCT)来将原始图像转换为频域中的系数,然后根据系数的重要性对其进行量化和编码。这样可以达到较高的压缩比,但也会引入一定的失真。 无损压缩是指压缩过程中不会丢失任何图像信息。最常用的无损压缩算法是ZIP算法。ZIP算法使用了哈夫曼编码和LZ77算法来寻找重复的数据块并进行压缩。这样可以减小文件大小,但不会改变图像的质量。 在解决图像压缩问题时,可以根据图像的特性来选择适当的压缩算法和参数。如果要求高压缩比并且可以接受一定的失真,可以选择JPEG算法;如果要求保持图像质量并且不要求高压缩比,可以选择ZIP算法。此外,还可以使用其他的图像压缩算法,如PNG、GIF等。 总结来说,图像压缩是通过减少图像的数据量来实现图像文件大小的减小。有损压缩和无损压缩是常用的两种图像压缩方法,分别适用于不同的需求和要求。通过选择合适的压缩算法和参数,可以实现理想的图像压缩效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值