这是一个非常简单的问题,但现在已经很晚了,我无法弄清楚为什么这个功能不起作用。我希望它打印1234,但它打印123121.有人可以解释发生了什么以及如何解决它?感谢
#include <iostream>
const int size = 20;
void set_int( int num )
{
int digits[size];
for ( int i = size - 1; i >= 0; i-- )
{
digits[i] = num % 10;
num /= 10;
if ( num != 0 )
std::cout << num;
}
}
int main()
{
set_int( 1234 );
return 0;
}
答案 0 :(得分:1)
你是输出数字而不是数字。
尝试改变,
cout << digits[i]
<强> Further clarification :
强>
在循环的第一次运行中,您的num将为1234 / 10 = 123
接下来,您的号码将为123 / 10 = 12
接下来将是1
您正在输出num,因此您获得了123121
。
答案 1 :(得分:0)
该代码存在一些问题。
首先,定义
int digits[size];
是一个可变长度数组,它是有效的C(自1999 C标准以来),但不是有效的C ++。不幸的是,一些C ++编译器支持诸如扩展之类的东西。
其次,即使我们假设定义有效,您的代码也基本上声明您需要一个包含1234个元素的数组来保存对应于四位数(1,2,3和4)的整数值。
正如MichaelCMS所描述的那样,您的代码也输出了除数字之外的其他内容。值1234有4位数,因此您需要循环总共4次才能找到所有数字(如果正确的话)。你不需要循环1234次。
答案 2 :(得分:0)
MichaelCMS正确解释了为什么你有这样的输出。你的功能有错误。我又写了一篇。
您可以使用下一个代码,这有助于查找数字的数字。
#include <iostream>
int FindNumberOfDigits(int number);
void SplitNumberIntoDigits(int number);
// Splits number into digits.
// Works with not big numbers.
void SplitNumberIntoDigits(int number)
{
int size = FindNumberOfDigits(number);
int * digits = new int[size];
int divider = 0;
int degree = 0;
for(int digit = size; digit > 0; digit --)
{
// Find degree of divider
degree = digit;
// Find divider for each digit of number.
// For 1234 it will be 1000. For 234 it will be 100.
divider = pow(10, degree - 1);
// We use "abs" to get digits without "-".
// For example, when -1234 / 1000, you get -1.
digits[digit] = abs(number / divider);
// Cut number to find remaining digits.
number %= divider;
std::cout << digits[digit];
}
std::cout << std::endl;
}
// If number = 0, number of digits will be 1.
// Else returns number of digits.
int FindNumberOfDigits(int number)
{
int digitsNumber = 0;
if (number)
{
// calculates number of digits
while (number / 10)
{
number /= 10;
digitsNumber ++;
}
}
digitsNumber += 1;
return digitsNumber;
}
int _tmain(int argc, _TCHAR* argv[])
{
SplitNumberIntoDigits(1234);
SplitNumberIntoDigits(0);
SplitNumberIntoDigits(1);
SplitNumberIntoDigits(-1234);
SplitNumberIntoDigits(1234567890);
return 0;
}
因此,此代码可以帮助您找到不大数字的数字。它适用于正数,负数和零。