华为OJ平台——密码强度等级
题目描述:
密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。
一、密码长度:
5 分: 小于等于4 个字符
10 分: 5 到7 字符
25 分: 大于等于8 个字符
二、字母:
0 分: 没有字母
10 分: 全都是小(大)写字母
20 分: 大小写混合字母
三、数字:
0 分: 没有数字
10 分: 1 个数字
20 分: 大于1 个数字
四、符号:
0 分: 没有符号
10 分: 1 个符号
25 分: 大于1 个符号
五、奖励:
2 分: 字母和数字
3 分: 字母、数字和符号
5 分: 大小写字母、数字和符号
最后的评分标准:
>= 90: 非常安全
>= 80: 安全(Secure)
>= 70: 非常强
>= 60: 强(Strong)
>= 50: 一般(Average)
>= 25: 弱(Weak)
>= 0: 非常弱
对应输出为:
VERY_WEAK,
WEAK,
AVERAGE,
STRONG,
VERY_STRONG,
SECURE,
VERY_SECURE
请根据输入的密码字符串,进行安全评定。
注:
字母:a-z, A-Z
数字:-9
符号包含如下: (ASCII码表可以在UltraEdit的菜单view->ASCII Table查看)
!"#$%&'()*+,-./ (ASCII码:x21~0x2F)
:;<=>?@ (ASCII<=><=><=><=><=>码:x3A~0x40)
[\]^_` (ASCII码:x5B~0x60)
{|}~ (ASCII码:x7B~0x7E)
输入:
输入一个string的密码(eg:38$@NoNoNo)
输出:
输出密码等级(eg:VERY_SECURE)
思路:
其实对于这样一个等级评定,主要考察的是密码字符串的长度、大写字母个数、小写字母个数、数字个数以及符号个数,然后根据这些标准来判断得分,最后根据得分来确定等级就可以了。主要是一些if语句的逻辑判断,算法层面的考察很少。
import java.util.Scanner;
public class GetPwdSecurityLevel {
public static void main(String[] args) {
Scanner cin = new Scanner(System.in) ;
String password = cin.nextLine() ;
cin.close() ;
SecurityLevel res = getPwdSecurityLevel(password) ;
System.out.println(res.name()) ;
}
/**
* 其实对于这样一个等级评定,
* 主要考察的是密码字符串的长度、大写字母个数、小写字母个数、数字个数以及符号个数
* 然后根据这些标准来判断得分,最后根据得分来确定等级
* @param password
* @return
*/
private static SecurityLevel getPwdSecurityLevel(String password) {
int len = password.length() ;
int countUpper = 0 ;
int countLower = 0 ;
int countNum = 0 ;
int countSym = 0 ;
int score = 0 ;
char temp ;
for(int i = 0 ; i < len ; i++){
temp = password.charAt(i) ;
if((temp <= 'Z') && (temp >= 'A')){
//大写字母个数
countUpper++ ;
}else if((temp <= 'z') && (temp >= 'a')){
//小写字母个数
countLower++ ;
}else if((temp <= '9') && (temp >= '0')){
//数字个数
countNum++ ;
}else if(((temp >= 0x21) && (temp <= 0x2F)) ||
((temp >= 0x3A) && (temp <= 0x40)) ||
((temp >= 0x7B) && (temp <= 0x7E))){
//符号个数
countSym++ ;
}
}
//计算根据长度判断的得分
if(len <= 4){
score += 5 ;
}else if((len <= 7) && (len > 4)){
score += 10 ;
}else{
score += 25 ;
}
//计算根据字母情况判断得分
if(((countUpper != 0) && (countLower == 0)) ||
((countUpper == 0) && (countLower != 0))){
score += 10 ;
}else if((countUpper != 0) && (countLower != 0)){
score += 20 ;
}
//计算根据数字个数判断得分
if(countNum == 1){
score += 10 ;
}else if(countNum > 1){
score += 20 ;
}
//计算根据符号个数判断的得分
if(countSym == 1){
score += 10 ;
}else if(countSym > 1){
score += 25 ;
}
//计算奖励的判断得分
if((countUpper != 0) && (countLower != 0) &&
(countNum != 0) && (countSym != 0)){
score += 5 ;
}else if(((countUpper + countLower) != 0) &&
(countNum != 0) && (countSym != 0)){
score += 3 ;
}else if(((countUpper + countLower) != 0) &&
(countNum != 0) && (countSym == 0)){
score += 2 ;
}
//根据得分确定最后的评级,并返回
if(score >= 90){
return SecurityLevel.VERY_SECURE ;
}else if(score >= 80){
return SecurityLevel.SECURE ;
}else if(score >= 70){
return SecurityLevel.VERY_STRONG ;
}else if(score >= 60){
return SecurityLevel.STRONG ;
}else if(score >= 50){
return SecurityLevel.AVERAGE ;
}else if(score >= 25){
return SecurityLevel.WEAK ;
}else{
return SecurityLevel.VERY_WEAK ;
}
}
}
/**
* 安全评级用枚举类型表示
*/
enum SecurityLevel{
VERY_WEAK,
WEAK,
AVERAGE,
STRONG,
VERY_STRONG,
SECURE,
VERY_SECURE
}
华为OJ平台——密码强度等级的更多相关文章
- 华为OJ平台——字符串分隔
题目描述: 连续输入字符串,请按长度为8拆分每个字符创 后输出到新的字符串数组: 长度不是8整数倍的字符串请在后面补数字0,空字符串不处理 输入 连续输入字符串(输入两次,每个字符长长度小于100)输 ...
- 华为OJ平台——输出最小的k个数
输入n个整数,输出其中最小的k个. 详细描述: 接口说明 原型: bool GetMinK(unsignedint uiInputNum, int *pInputArray, unsignedint ...
- 华为OJ平台——矩阵乘法
题目描述: 如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C. 输入: 1.第一个矩阵的行数 2.第一个矩阵的列数(也是第二个矩阵的行数) 3.第二个矩阵 ...
- 华为OJ平台——求最大连续bit数
题目描述: 求一个byte数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1 输入: 一个byte型的数字 输出: 对应的二进制数字中1的最大连续数 思路: ...
- 华为OJ平台——统计字符串中的大写字母
题目描述: 统计字符串中的大写字母的个数 输入: 一行字符串 输出: 字符串中大写字母的个数(当空串时输出0) 思路: 这一题很简单,直接判断字符串中的每一个字符即可,唯一要注意的一点是输入的字符串可 ...
- 华为OJ平台——将真分数分解为埃及分数
题目描述: 分子为1的分数称为埃及分数.现输入一个真分数(分子比分母小的分数,叫做真分数),请将该分数分解为埃及分数.如:8/11 = 1/2+1/5+1/55+1/110. 输入: 输入一个真分数, ...
- 华为OJ平台——字符串匹配
题目描述: 判断短字符串中的所有字符是否在长字符串中全部出现 输入: 输入两个字符串. 第一个为短字符,第二个为长字符 输出: true - 表示短字符串中所有字符均在长字符串中出现 false - ...
- 华为OJ平台——整形数组合并
题目描述: 将两个整型数组按照升序合并,并且过滤掉重复数组元素 输入: 输入说明,按下列顺序输入: 1 输入第一个数组的个数 2 输入第一个数组的数值 3 输入第二个数组的个数 4 输入第二个数组的数 ...
- 华为OJ平台——计算字符串的相似度
题目描述: 对于不同的字符串,我们希望能有办法判断相似程度,我们定义了一套操作方法来把两个不相同的字符串变得相同,具体的操作方法如下: 1 修改一个字符,如把“a”替换为“b”. 2 增加一个字符,如 ...
随机推荐
- 怎样进行Android UI元素设计
Android UI元素里面包含了许多的内容,比如:该平台由操作系统.中间件.用户界面和应用软件组成,一个应用程序要想受用户喜爱,那么UI可不能差. Android为相似的编程名词引入了一些新的术语, ...
- SQL Server 中LEN函数的问题
LEN('T ') =1 LEN(' T') =2 在数据库中分解字符串时要注意,例如以'^'分隔'X ^ T ',分解时要注意最后的'T '被分解成'T' 可用如下的代码来进行完整的分解 SET A ...
- Linux使用笔记: 定制core dump文件的文件名
在开发过程中,当一个Linux程序异常退出时,我们可以通过core文件来分析它异常的详细原因.缺省情况下,Linux在程序异常时不产生core文件,要想让程序异常退出时产生core dump文件,需要 ...
- Codeforces Round #365 (Div. 2) Mishka and trip
Mishka and trip 题意: 有n个城市,第i个城市与第i+1个城市相连,他们边的权值等于i的美丽度*i+1的美丽度,有k个首都城市,一个首都城市与每个城市都相连,求所有边的权值. 题解: ...
- 实现读入一个彩色视频文件并以灰度格式输出这个视频文件,学习opencv例2-10
#include "cv.h"#include "highgui.h"int main(int argc,char* argv[]){ //书本中的main没有 ...
- 转--android Toast大全(五种情形)建立属于你自己的Toast
Toast用于向用户显示一些帮助/提示.下面我做了5中效果,来说明Toast的强大,定义一个属于你自己的Toast. 1.默认效果 代码 Toast.makeText(getApplicationCo ...
- M2M协议
1, M2M协议 M2M是Machine-to-Machine/Man的简称,是一种以机器终端智能交互为核心的.网络化的应用与服务.M2M协议规定了人机和机器之间交互需要遵从的通信协议.随着科学技术的 ...
- 使用Visual Studio 2013 调试 MASM 汇编程序!
原文地址:http://kipirvine.com/asm/debug/vstudio2013/index.htm Using the Microsoft Visual Studio 2013 Deb ...
- ruby-rails 环境搭建
https://ruby-china.org/wiki/install_ruby_guide
- C++学习29 重载[](下标运算符)
前面已经提到,下标操作符[]必须以类的成员函数的形式进行重载.在类中的声明格式如下: 返回值类型 & operator[] (参数) 或 const 返回值类型 & operator[ ...