一个判断密码强度问题:

假设允许采用以下四类字符作为密码:
(1)大写英文字母,(2)小写英文字母,(3)数字0-9,(4)特殊符号 @ - _ # ~
对密码强度做以下规定:
Best: 长度>=16,且包含以上四类字符,且每类至少有两个不同的字符
Strong: 不符合Best规定,但长度>=10,且包含以上四类字符
Medium: 不符合Best、Strong规定,但长度>=8,且包含以上至少三类字符
Weak:不符合Best、Strong、Medium规定。
现给你一个密码组合,请判断密码强度。
输入格式:一行字符串(长度<100,以换行结束),且保证都是以上四类字符。
输出格式:一行信息,先输出密码长度,然后是强度等级,中间空一格。

输入样例1:abcdXYZ1234@-_-#
输出样例1:16 Best
输入样例2:12345678abcdefghXYZ
输出样例2:19 Medium
输入样例3:aX1@
输出样例3:4 Weak

题目关键在于Best里面的每类至少有两个不同的字符,若想实现此功能可以定义多个数组。

c源代码:
#include"stdio.h"
int main()
{
char a[100],sz[100],ZM[100],zm[100],fh[100];
int i,j,k,l,m,n,sum,zm0,ZM0,sz0,fh0;
i=0;
k=l=m=n=0;
zm0=0;
ZM0=0;
sz0=0;
fh0=0;
sum=0;
while((a[i]=getchar())!='\n')
{
i++;
}
for(j=0;j<i;j++)
{
if(a[j]>='A'&&a[j]<='Z')
{
ZM[k]=a[j];
k++;
}

else if(a[j]>='a'&&a[j]<='z')
{
zm[l]=a[j];
l++;
}
else if(a[j]>='0'&&a[j]<='9')
{
sz[m]=a[j];
m++;
}
else
{
fh[n]=a[j];
n++;
}
}
sum=k+l+m+n;
while(k--)
    {
        ZM0++;
        if(ZM[k]==ZM[k-1])
            ZM0--;
    }
    while(l--)
    {
        zm0++;
        if(zm[l]==zm[l-1])
            zm0--;
    }
    while(m--)
    {
        sz0++;
        if(sz[m]==sz[m-1])
            sz0--;
    }
    while(n--)
    {
        fh0++;
        if(fh[n]==fh[n-1])
            fh0--;
    }
if(sum>=16&&ZM0>=2&&zm0>=2&&sz0>=2&&fh0>=2)
printf("%d Best\n",sum);
else if(sum>=10&&ZM0>=1&&zm0>=1&&sz0>=1&&fh0>=1)
printf("%d Strong\n",sum);
else if(sum>=8&&((ZM0>=1&&zm0>=1&&sz0>=1)||(zm0>=1&&ZM0>=1&&fh0>=1)||(zm0>=1&&sz0>=1&&fh0>=1)))
printf("%d Medium\n",sum);
else
printf("%d Weak\n",sum);
return 0;
}

【课上OJ】判断密码强度的更多相关文章

  1. Js判断密码强度并显示提示信息

    用javascipt实现的Ajax判断密码强弱的功能,大多数有用户注册功能的网站,都会有这么一个功能,作为WEB程序员,应该会写这种小模块哦,不懂的就看下这个例子,觉得挺简单,当初帮助了不少人学会了密 ...

  2. js判断密码强度是否符合

    /** 判断密码强度是否符合 */ function check_passwd_intensity(password) { value = $.trim(password); if( value.le ...

  3. JavaScript判断密码强度

    以下是代码: <html> <head> <title>JS判断密码强度</title> <script language=javascript& ...

  4. js判断密码强度

    html代码: <form name="form1" action=""> 密码:<input type="password&quo ...

  5. js动态判断密码强度&&实用的 jQuery 代码片段

    // 网上拷贝的代码,效果不太好需要自己调整<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &q ...

  6. 【课上OJ】掉入陷阱的数

    对任意一个自然数N0,先将其各位数字相加求和,再将其和乘以3后加上1,变成一个新自然数N1,然后对N1重复这种操作,可以产生新自然数N2,多次重复这种操作运算,运算结果最终会得到一个固定不变的数Nk, ...

  7. PHP 判断密码强度

                 $score = 0;            if(preg_match("/[0-9]+/",$str))            {           ...

  8. php判断密码强度函数

    其实就是一些策略正则,写好了就留下来以后用. print_r(getPasswordStrength('s1212adsddfASD;\'g;\'gh.h,h..;')); function getP ...

  9. 利用JavaScript来实现用动态检验密码强度

    平时我们会在某些网站的注册页面或者更改密码的页面发现当我们输入密码时,会有一个类似于进度条的长条进行提示用户输入的密码强度.如下图: 我看到有些人用几张不同的图片来替换,这样似乎可以,但是不太好.所以 ...

随机推荐

  1. [Poetize I]守卫者的挑战

    描述 Description 打开了黑魔法师Vani的大门,队员们在迷宫 般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者.如果 ...

  2. QR分解

        从矩阵分解的角度来看,LU和Cholesky分解目标在于将矩阵转化为三角矩阵的乘积,所以在LAPACK种对应的名称是trf(Triangular Factorization).QR分解的目的在 ...

  3. 西装定制平台Indochino获$1350万B轮融资 - 国际B2C - 亿邦动力网

    西装定制平台Indochino获$1350万B轮融资 - 国际B2C - 亿邦动力网 西装定制平台Indochino获$1350万B轮融资 作者: 韦龑来源: i黑马网2013-03-29 11:05 ...

  4. 部分实用的SQL语句

    一.在数据库创建表格的SQL语句 1,创建一个link表格,包含属性:lid  主键,title 标题,  imgpath 图片地址 , url  网址  , info 说明,  isshow 显示1 ...

  5. 一个Nodejs的简单计算測试程序

    測试目的: 1 測试二维数组的使用 2 输出函数的使用 代码: var util = require('util'); a = 3; b = 4; c = a + b; a = []; for(i = ...

  6. SHELL网络爬虫实例剖析--转载

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://nolinux.blog.51cto.com/4824967/1552472 前天 ...

  7. divmod(a,b)函数

    python每日一函数 - divmod数字处理函数 divmod(a,b)函数 中文说明: divmod(a,b)方法返回的是a//b(除法取整)以及a对b的余数 返回结果类型为tuple 参数: ...

  8. 快速使用shortcut,适配各种ROM

    地址(徐医生的GitHub):https://github.com/xuyisheng/ShortcutHelper 常用API     /**      * 添加快捷方式      *      * ...

  9. 安装VS2013的离线MSDN帮助文档

    作为vs的初学者,安装帮助文档有利于快速掌握.net的基本语法,对于摸索学习的同学帮助很大. VS2013和VS2012的帮助文档目前为止还是一样 下面是下载地址    http://www.micr ...

  10. activeMQ总结

    队列模式和发布订阅模式的区别 topic只有所有订阅者都消费了,这个消息才会消失.只要有一个订阅者没有消费(持久化模式),这个消息就会存在.订阅者下线然后上线也会读取到这个消息.而且队列的话,消费能力 ...