华为OJ 密码验证合格程序
2016-04-08 15:50
381 查看
import java.util.*;
/*
* .长度超过8位
2.包括大小写字母.数字.其它符号,以上四种至少三种
3.不能有相同长度超2的子串重复
*/
//解题思路:只需要按要求一步一步来就行,我用的最笨的方法,其中在验证字符重复时,使用的两层循环,第二层循环就开始查看有没有与第一层相同的字符,如果有的话,一个while,直到没有相同的结束,此时看共多少个一样的,如果超过两个就是NG.
import java.util.*;
public class huiwen{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
String s=null;
int len=0;
boolean re=true;
while(sc.hasNext()){
s=sc.nextLine();
len=s.length();
//判断这个串是否正确
re=pim(s);
if(re)
System.out.println("OK");
else
System.out.println("NG");
}
}
//判断串函数
public static boolean pim(String s){
int len=s.length();
int[] a = new int[4];
//先验证长度
if(len<=8)
return false;
//然后验证至少三种字符
for(int i=0;i<len;i++){
if(s.charAt(i)>='0'&&s.charAt(i)<='9')
a[0]=1;
else if(s.charAt(i)>='A'&&s.charAt(i)<='Z')
a[1]=1;
else if(s.charAt(i)>='a'&&s.charAt(i)<='z')
a[2]=1;
else
a[3]=1;
}
int count=0;
for(int i=0;i<4;i++)
if(a[i]==1)
count++;
if(count<3)
return false;
else{
//再验证是否重复大于2
for(int i=0;i<len;i++)
for(int j=i+1;j<len;j++){
if(s.charAt(j)==s.charAt(i)){
int k;
for(k=0;k<len-j;k++){
if(s.charAt(j+k)!=s.charAt(i+k))
break;
}
if(k>2)
return false;
}
}
}
return true;
}
}
/*
* .长度超过8位
2.包括大小写字母.数字.其它符号,以上四种至少三种
3.不能有相同长度超2的子串重复
*/
//解题思路:只需要按要求一步一步来就行,我用的最笨的方法,其中在验证字符重复时,使用的两层循环,第二层循环就开始查看有没有与第一层相同的字符,如果有的话,一个while,直到没有相同的结束,此时看共多少个一样的,如果超过两个就是NG.
import java.util.*;
public class huiwen{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
String s=null;
int len=0;
boolean re=true;
while(sc.hasNext()){
s=sc.nextLine();
len=s.length();
//判断这个串是否正确
re=pim(s);
if(re)
System.out.println("OK");
else
System.out.println("NG");
}
}
//判断串函数
public static boolean pim(String s){
int len=s.length();
int[] a = new int[4];
//先验证长度
if(len<=8)
return false;
//然后验证至少三种字符
for(int i=0;i<len;i++){
if(s.charAt(i)>='0'&&s.charAt(i)<='9')
a[0]=1;
else if(s.charAt(i)>='A'&&s.charAt(i)<='Z')
a[1]=1;
else if(s.charAt(i)>='a'&&s.charAt(i)<='z')
a[2]=1;
else
a[3]=1;
}
int count=0;
for(int i=0;i<4;i++)
if(a[i]==1)
count++;
if(count<3)
return false;
else{
//再验证是否重复大于2
for(int i=0;i<len;i++)
for(int j=i+1;j<len;j++){
if(s.charAt(j)==s.charAt(i)){
int k;
for(k=0;k<len-j;k++){
if(s.charAt(j+k)!=s.charAt(i+k))
break;
}
if(k>2)
return false;
}
}
}
return true;
}
}
相关文章推荐
- 华为路由器密码恢复
- 华为交换机的后缀详解
- 华为RAID 1阵列卡设置教程图文详解
- 华为的IPD流程
- 华为手机真机调试设置
- 华为OR小米,谁是智能手机出货量之王?
- 抢先小米!NFC支付又添一家 华为推出Huawei Pay
- SE100101系统概述
- 华为防火墙配置演示 Quidway SecPath
- 华为防火墙地址转换
- 华为(VRRP-OSPF-STP-SNMP链路聚合)
- S9300做VRRP的配置
- 配置负载分担VRRP
- 华为9306(9300系列)在不删除配置的情况下恢复密码
- 思科和华为交换机常用命令对比学习
- 华为网络技术培训笔记之常用网络工具(一)
- 华为网络技术培训笔记之常用网络工具(二)
- 华为1821路由器qos car+nat+dhcp+vlan配置心得
- 华为交换机-端口由trunk改为access