private static String[] mustExistNumber = new String[] { “1”, “2”, “2”, “3”, “4”, “5” };
private static boolean isValidNumber(String str) {
// 检查是否包含12345这五个数,不包含返回false
for (String number : mustExistNumber) {
if (str.indexOf(number) < 0)
return false;
}
// 检查是否有两个2,只有一个返回false
if (str.lastIndexOf("2") == str.indexOf("2")) {
return false;
}
// 检查4在不在第三位,是返回false
if (str.charAt(2) == '4') {
return false;
}
// 检查是否存在35在一起,有返回false
if (str.indexOf("35") >= 0 || str.indexOf("53") >= 0) {
return false;
}
return true;
}
public static void main(String[] args) {
int count=0;
for (int i = 122345; i <=543221; i++) {
if (isValidNumber(String.valueOf(i))) {
System.out.println(i);
count++;
}
}
System.out.println(count);
}
本文介绍了一种算法,用于验证数字序列是否符合特定规则,包括检查数字序列中是否包含特定数字、数字的位置以及特定数字组合的存在。通过遍历指定范围内的数字并应用此算法,筛选出符合条件的数字序列。

被折叠的 条评论
为什么被折叠?



