在一定间隔内对数字的位数进行计数

Counting digits of a number in a certain interval

本文关键字:数字      更新时间:2023-10-16

我必须制作一个c++程序,计算区间[m=1000;n=1100]内的数字是否有偶数位数。

但使用我写的这个程序,我得到了一个无尽的循环。

int digits(int m, int n)
{
int i, count_digits = 0;
for(i = m; i < n; i++)
{
while(i != 0)
{
i = i/10;
count_digits++;
}
}
if(k%2 == 0) return count_digits;
}

循环内

for(i = m; i < n; i++)
{
while(i != 0)
{
i = i/10;
count_digits++;
}
}

您正在更改变量i.

再引入一个局部变量

for(i = m; i < n; i++)
{
int value = i;
while(value != 0)
{
value /= 10;
count_digits++;
}
}

您似乎还需要在循环的每次迭代中重新初始化变量count_digits

for(i = m; i < n; i++)
{
int value = i;
count_digits = 0;
while(value != 0)
{
value /= 10;
count_digits++;
}
}

请注意,您的循环是在值[m,n-1]的范围内执行的,而不是您在问题中所写的范围[m,n]。

此外,还不清楚中使用的变量k在哪里

if(k%2 == 0) return count_digits;

已声明。

我猜你需要像下面这样的

#include <iostream>
int main() 
{
const int M = 1000;
const int N = 1100;
const int Base = 10;
for ( int i = M; i <= N; i++ )
{
int value = i;
size_t count_digits = 0;
do 
{ 
if ( value % Base != 0 ) ++count_digits; 
} while ( value /= Base );
if ( count_digits % 2 == 0 ) std::cout << i << ' ';
}
std::cout << 'n';
return 0;
}

程序输出为

1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1020 1030 1040 1050 1060 1070 1080 1090 1100

在任何情况下,您都可以将该程序视为您的程序的基础。