【问题描述】
开发一个密码检查软件,密码要求:
-
长度超过8位
-
包括大小写字母.数字.其它符号,以上四种至少三种
-
不能有相同长度超2的子串重复
【输入形式】
一组或多组长度超过2的子符串。每组占一行
【输出形式】
如果符合要求输出:OK,否则输出NG
【样例输入】
021Abc9000
021Abc9Abc1
021ABC9000
021$bc9000
【样例输出】
OK
NG
NG
OK
import java.util.Scanner;
public class Hh {
public static boolean chongfuZC(String x) {
for(int i=0;i<x.length()-3;i++) {
String a=x.substring(i+1);
String b=x.substring(i,i+3);
if(a.contains(b)) {
return true;
}
}
return false;
}
public static void main(String[] args) {
Scanner sca=new Scanner(System.in);
String a;
while(sca.hasNextLine()) {
a=sca.nextLine();
if(a.length()<=8) {
System.out.println("NG");
continue;
}
int[] z= {0,0,0,0};
for(int i=0;i<a.length();i++) {
if(a.charAt(i)>='0'&&a.charAt(i)<='9') {
z[0]=1;
}
else if(a.charAt(i)>='a'&&a.charAt(i)<='z') {
z[1]=1;
}
else if(a.charAt(i)>='A'&&a.charAt(i)<='Z') {
z[2]=1;
}
else z[3]=1;
}
if((z[0]+z[1]+z[2]+z[3])<3) {
System.out.println("NG");
continue;
}
if(chongfuZC(a)) {
System.out.println("NG");
continue;
}
System.out.println("OK");
}
sca.close();
}
}