在一定间隔内对数字的位数进行计数
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
在任何情况下,您都可以将该程序视为您的程序的基础。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 检查输入是否不是整数或数字
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- 如何用数字处理log(0)
- 最高有效数字侧的第N位
- 如何获取一个数字的前3位
- 查找最接近的大于当前数字的数字的索引
- 找到两对数字,使它们的乘积的绝对差最小化
- 我想做一个彼此不同但重复出现的数字
- 将数字转换为字母(例如:123 转换为一二三)
- C++如何计算用户输入的数字中的偶数位数
- 如何在C++中确定文本文件中的元素是字符还是数字
- 打印数字图案
- C++问题:用户认为数字1-100,程序提出问题不超过6次即可得到答案。无法正确
- 如何检查一个c++字符串中有多少相同的字符/数字
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 将数字打印成文字
- 当使用比格式支持的精度更高的精度来显示数字时,会写出什么数据
- 在将数字随机生成为数组期间从内存输出随机数的数组