用循环等方式依次去枚举所有的数字组合,一一验证是否符合题目的要求
题目链接
0好数 - 蓝桥云课
题目解析
好数的概念: 数的奇数位位奇数,偶数位为偶数,就是一个好数
求输入n里面有多少个好数
题目原理
1> 遍历每个数
2> 每次遍历判断是不是好数
把这个数的每一位取出来进行判断是奇还是偶
使用一个变量来表示奇数位还是偶数位,每次判断完一个后就++(或者每次循环就直接++)
完整代码
import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改
public class Main {
private static int isGoodNum(int num) {
int evenOr = 0;
//取出每一位
while (num != 0) {
evenOr++;
int pos = num % 10;
num = num / 10;
//判断这个数奇数数位是不是奇数
if ((evenOr % 2 == 1) && (pos % 2) == 0) {
return 0;
}
if ((evenOr % 2 == 0) && (pos % 2) == 1) {
return 0;
}
}
//能够到这里说明奇数位是奇数,偶数位是偶数
return 1;
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
//输入这个数
int num = scan.nextInt();
int count = 0;
//计算好数的个数
for (int i = 1; i <= num; i++) {
//判断每一个数是不是好数
count += isGoodNum(i);
}
System.out.println(count);
}
}