思路:
历遍所有你需要的数字
通过 %10 获得末位的数字 来判断
再通过 /=10 把数字进一步加工 来得出结论
//蓝桥杯2024 好数
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
int n;
cin >> n;
int daan = 0;
for (int i = 1; i <= n; i++) { //历遍这个
bool t = true;
int num = i;
int os = 1; // 这是这个数的第os个数
while (num > 0) {
if (os % 2 == 0) { // 偶数
if ((num % 10) % 2 != 0) { // 位置上的不是偶数
t = false;
break;
}
}
else {
if ((num % 10) % 2 == 0) { // 位置上的不是奇数
t = false;
break;
}
}
os++;
num /= 10;
}
if (t == true) {
daan++;
}
}
cout << daan << endl;
return 0;
}