Talk is cheap, show me the code.
一、问题描述
密码要求:
1.长度超过8位
2.包括大小写字母.数字.其它符号,以上四种至少三种
3.不能有相同长度超2的子串重复
说明:长度超过2的子串
输入描述:
一组或多组长度超过2的子符串。每组占一行
输出描述:
如果符合要求输出:OK,否则输出NG
输入例子:
021Abc9000
021Abc9Abc1
021ABC9000
021$bc9000
输出例子:
OK
NG
NG
OK
二、问题分析
判断大小写字母、数字、其他符号要么采用字符串find_first_of函数,要么进行一次循环遍历也可以统计出来。不能有相同长度超2的子串重复,其实就是说不能有长度为3的子串重复,这个可以通过字符串的find函数来实现,也可以通过遍历比较连续的3个字符来实现。
采用字符串的函数来实现。
#include <iostream>
#include <string>
#include <cctype>
using namespace std;
int main()
{
string pd;
while (cin >> pd)
{
if (pd.