问题描述
一个整数如果按从低位到高位的顺序,奇数位 (个位、百位、万位 ⋯⋯ ) 上的数字是奇数,偶数位 (十位、千位、十万位 ⋯⋯ ) 上的数字是偶数,我们就称之为 "好数"。
给定一个正整数 NN,请计算从 1 到 NN 一共有多少个好数。
输入格式
一个整数 NN。
输出格式
一个整数代表答案。
样例输入 1
24
样例输出 1
7
样例输入 2
2024
样例输出 2
150
样例说明
对于第一个样例,2424 以内的好数有 11、33、55、77、99、2121、2323,一共 77 个。
评测用例规模与约定
对于 10%10% 的评测用例,1≤N≤1001≤N≤100 。
对于 100%100% 的评测用例,1≤N≤1071≤N≤107 。
运行限制
语言 | 最大运行时间 | 最大运行内存 |
---|---|---|
C++ | 1s | 256M |
C | 1s | 256M |
Java | 3s | 512M |
Python3 | 10s | 512M |
PyPy3 | 3s | 512M |
Go | 5s | 512M |
JavaScript | 5s | 512M |
思路
for循环 if 判断 直接暴力就完了
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
long long n;
long long ans=0;
scanf("%lld",&n);
for(;n>=1;n--){
int i=1;
for(long long m=n;m>0;){
if(i==1){
if(m%2!=0){
m=m/10;
i=2;
}
else{
i=2;
break;
}
}
if(i==2){
if(m%2==0){
m=m/10;
i=1;
}
else{
i=1;
break;
}
}
if(m==0){
ans++;
}
}
}
printf("%lld",ans);
return 0;
}