编程题——密码强度等级

密码强度检测与等级划分
该编程题旨在根据特定规则评估密码强度,并将其分为不同安全等级,如VERY_SECURE、SECURE等。通过给出的代码,程序能计算并显示密码的强度等级。

编程题——密码强度等级


题目描述:
密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。

   一、密码长度:

   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_SECURE
SECURE
VERY_STRONG
STRONG
AVERAGE
WEAK
VERY_WEAK


程序代码如下:



#include <iostream>
#include <string>
using namespace std;

/*这道题其实非常简单,只是题目看起来繁琐而已*/

//检查字母:没有返回0;全部大(小)写返回10;大小写混合返回20
int AboutLetter(const string& s,int length)
{
	int big = 0, small = 0;
	for (int i = 0; i < length; ++i)
	{
		if (s[i] >= 'a' && s[i] <= 'z')
			++small;
		else if (s[i] >= 'A' && s[i] <= 'Z')
			++big;
	}

	if ((small + big) == 0)
		return 0;
	else if (small == length || big == length)
		return 10;
	else if (small > 0 && big > 0)
		return 20;
	return 0;
}

//检查数字个数:没有返回0;有一个返回10;大于一个返回20
int NumOfNumber(const string& s, int length)
{
	int count = 0;
	for (int i = 0; i < length; ++i)
	{
		if (s[i] >= '0' && s[i] <= '9')
			++count;
	}
	if (0 == count)
		return 0;
	else if (1 == count)
		return 10;
	else
		return 20;
}

//检查符号个数:没有返回0;有一个返回10;大于一个返回25
int NumOfSymbol(const string& s, int length)
{
	int count = 0;
	for (int i = 0; i < length; ++i)
	{
		//不是数字也不是字母的话就是符号了
		if (!(s[i] >= '0' && s[i] <= '9')&&
			!(s[i] >= 'a' && s[i] <= 'z')&&
			!(s[i] >= 'A' && s[i] <= 'Z'))
			++count;
	}
	if (0 == count)
		return 0;
	else if (1 == count)
		return 10;
	else
		return 25;
}

int main()
{
	int sum1 = 0, sum2 = 0, sum3 = 0, sum4 = 0, sum5 = 0;
	string s;
	while (getline(cin, s))
	{
		int length = s.size();
		//sum1保存密码长度的分数
		if (length <= 4)
			sum1 = 5;
		else if (length <= 7)
			sum1 = 10;
		else
			sum1 = 25;

		sum2 = AboutLetter(s, length);//sum2保存字母的分数
		sum3 = NumOfNumber(s, length);//sum3保存数字的分数
		sum4 = NumOfSymbol(s, length);//sum4保存符号的分数

		//sum5保存奖励分
		if (sum2 > 0 && sum3 > 0)
		{
			if (sum4 > 0)
			{
				if (20 == sum2)
					sum5 = 5;
				else
					sum5 = 3;
			}
			else
				sum5 = 2;
		}

		//根据得分情况对应输出安全等级
		if (sum1 + sum2 + sum3 + sum4 + sum5 >= 90)
			cout << "VERY_SECURE" << endl;
		else if (sum1 + sum2 + sum3 + sum4 + sum5 >= 80)
			cout << "SECURE" << endl;
		else if (sum1 + sum2 + sum3 + sum4 + sum5 >= 70)
			cout << "VERY_STRONG" << endl;
		else if (sum1 + sum2 + sum3 + sum4 + sum5 >= 60)
			cout << "STRONG" << endl;
		else if (sum1 + sum2 + sum3 + sum4 + sum5 >= 50)
			cout << "AVERAGE" << endl;
		else if (sum1 + sum2 + sum3 + sum4 + sum5 >= 25)
			cout << "WEAK" << endl;
		else
			cout << "VERY_WEAK" << endl;
	}
	return 0;
}


程序运行结果如下:


在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值