当前位置: 首页 > wzjs >正文

网站建设公司河南郑州淘宝关键词指数

网站建设公司河南郑州,淘宝关键词指数,手机app网站模板下载,建设网站商城题目 你需要书写一个程序验证给定的密码是否合格。 合格的密码要求: 长度超过 8 位必须包含大写字母、小写字母、数字、特殊字符中的至少三种不能分割出两个独立的、长度大于 2 的连续子串,使得这两个子串完全相同;更具体地,如果…

题目

你需要书写一个程序验证给定的密码是否合格。
合格的密码要求:

  • 长度超过 8 位
  • 必须包含大写字母、小写字母、数字、特殊字符中的至少三种
  • 不能分割出两个独立的、长度大于 2 的连续子串,使得这两个子串完全相同;更具体地,如果存在两个长度大于 2 的独立子串 s1​,s2​ ,使得 s1​=s2​ ,那么密码不合法。

子串为从原字符串中,连续的选择一段字符(可以全选、可以不选)得到的新字符串。

可见字符集为 ASCII 码在 33 到 126 范围内的可见字符。

示例

若密码合格,输出 OK ,否则输出 NG 。

示例1

输入:

021Abc9000
021Abc9Abc1
021ABC9000
021$bc9000
021Abc1111

输出:

OK
NG
NG
OK
OK

说明:对于第二组测试数据,"Abc9Abc1" 中存在两个长度大于 2 的独立子串 "Abc"。
           对于第三组测试数据,仅包含大写字母和数字,不满足条件。

示例2

输入:

Abc1@
A1@ababa@1A

输出:

NG
OK

说明:对于第一组测试数据,长度不足 8 位,不满足条件。

分析

哈希表+枚举

字符类型检查:在 hasThreeTypes 函数中,使用了遍历算法。通过遍历密码字符串中的每个字符,利用字符处理函数(如 std::isupperstd::islowerstd::isdigit)对字符进行分类判断,以确定密码中是否包含大写字母、小写字母、数字和特殊字符。

重复子串检查:在 hasRepeatedSubstring 函数中,结合了子串枚举和哈希表(std::unordered_set)的算法思想。首先,通过两层循环枚举所有可能的子串长度和起始位置,然后使用 std::unordered_set 来存储已经出现过的子串。在遍历过程中,如果发现某个子串已经存在于哈希表中,就说明存在重复子串。

时间复杂度:O(n^{2}), n 是字符串的长度

空间复杂度:O(n)

#include <iostream>
#include <string>
#include <unordered_set>
#include <cctype>// 检查密码是否包含至少三种类型的字符
bool hasThreeTypes(const std::string& password) {bool hasUpper = false, hasLower = false, hasDigit = false, hasSpecial = false;for (char c : password) {if (std::isupper(c)) hasUpper = true;else if (std::islower(c)) hasLower = true;else if (std::isdigit(c)) hasDigit = true;else if (c >= 33 && c <= 126) hasSpecial = true;}int typeCount = 0;if (hasUpper) ++typeCount;if (hasLower) ++typeCount;if (hasDigit) ++typeCount;if (hasSpecial) ++typeCount;return typeCount >= 3;
}// 检查密码中是否存在两个长度大于 2 的相同独立连续子串
bool hasRepeatedSubstring(const std::string& password) {int n = password.length();for (int len = 3; len <= n / 2; ++len) {std::unordered_set<std::string> seen;for (int i = 0; i <= n - len; ++i) {std::string sub = password.substr(i, len);if (seen.find(sub) != seen.end()) {return true;}seen.insert(sub);}}return false;
}// 验证密码是否合格
bool isPasswordValid(const std::string& password) {// 检查长度是否超过 8 位if (password.length() <= 8) return false;// 检查是否包含至少三种类型的字符if (!hasThreeTypes(password)) return false;// 检查是否存在两个长度大于 2 的相同连续子串if (hasRepeatedSubstring(password)) return false;return true;
}int main() {std::string s;while (std::getline(std::cin, s)) {if (isPasswordValid(s)) {std::cout << "OK" << std::endl;} else {std::cout << "NG" << std::endl;}}return 0;
}    
http://www.dtcms.com/wzjs/484848.html

相关文章:

  • 主营网站建设品牌站长之家排名查询
  • 谈谈网站建设会有哪些问题百度开户公司
  • 炫酷网站建设百度指数的使用
  • 建网站教程视频下载手机制作网站的软件
  • 深圳市长城建设有限公司网站企业官网推广
  • 临沂企业网站建设公司网站模板哪里好
  • 电子商务网站设计内容百度开户联系方式
  • 预约小程序模板江西优化中心
  • 制作ppt的网站地推团队如何收费
  • 网站添加背影音乐怎么做sem是什么工作
  • 昆山花桥做网站成都短视频代运营
  • 网站备案幕布尺寸中国十大it培训机构排名
  • 门户网站ip地址段长沙网站关键词排名公司
  • 做运动鞋评价的网站seo建站技巧
  • wordpress 是谁开发的优化关键词排名seo软件
  • 做招聘网站做服务器多少钱外贸网站制作
  • 怎么做简单地网站全球搜索引擎排名
  • 交流平台网站怎么做不了连云港seo优化公司
  • 青白江区建设局网站引擎seo如何优化
  • 企业为什么做平台网站收录优美图片找不到了
  • 什么网站可以兼职做鸭子怎么搭建自己的网站
  • 个人网页设计作品模板代码怎么写百度seo排名规则
  • 杭州企业云网站建设东莞网络排名优化
  • 外贸网站如何建设直通车关键词优化口诀
  • 做住宿的网站360优化大师安卓手机版下载安装
  • 深圳企业网站制作公司怎样网站制作公司官网
  • 企业内网网站网站seo排名优化软件
  • 网站服务器买了后怎么做的引擎搜索是什么意思
  • 2015年做哪些网站能致富seo是谁
  • 上海建设银行网站转账记录吗百度竞价外包