我必须编写一个 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
在任何情况下,您都可以将该程序视为您程序的基础。
关于c++ - 计算某个数在一定区间内的位数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58605181/