我正在学习自己的 c++,我想:“我在哪里可以找到一些问题来解决?”...好吧,阅读 stackoverflow 我对 euler 项目产生了兴趣,我来了。
我正在做第 4 个问题(顺便说一句,不是寻求帮助),但我有一个非常奇怪的问题...
在这段代码中,我想用“数字”分隔一个数字......这样我就可以说:如果数字的第一位数字等于最后一位数字,则它是一个回文数(可以读取的数字从左到右或从右到左将是相同的数字...例如:90009)。
一切都很好,但问题是当我尝试将一个数组元素划分为一个幂... 例如:
90009/power(10,4)=9 对吗? (当然使用整数)... 好吧,代码将 9 分配给 arregloDeNumero[4],然后
arregloDeNumero[4]*pow(10,4)= 89999 :O :O ???????????? 它必须是 90000 对吗?
另外,我放了一些 cout<< 代码,如果你想运行这个函数,看看它在我的脑海中是如何工作的:P
但我的问题是:是否有我编写的错误代码,或者是某种错误或缺乏知识?
void verificarPalindromo(int x)
{
int arregloDeNumero[6];
int diferencia=0;
for (int i=5;i>=0;i--){
cout << "the number X is: " << x;
cout << "and the difference is: " << diferencia << endl;
arregloDeNumero[i]= ((x-diferencia)/pow(10,i));
cout << "array of i= " << i << "is: " << arregloDeNumero[i];
cout << " and the difference is: " << diferencia << endl;
diferencia+=(arregloDeNumero[i]*pow(10,i));
cout << "the new difference is: " << diferencia << endl;
}
}
最佳答案
虽然您的代码不包含任何 float ,但pow()
函数返回double
并且您对 float 的理解似乎有问题。通常情况下,除以 float 可能会导致一个值与确切结果有非常轻微的差异(可能只有一位)。当这样的值转换为整数时,它会被截断并生成下一个较小的整数。
你应该
a) 使用完全使用整数实现的策略,或者 b) 使用 float ,但确保转换为 int 使用舍入而不是截断。
如果你有足够高的警告级别,编译器应该告诉你这个潜在的问题。
明确一点,我认为问题出在这里:
((x-diferencia)/pow(10,i))
对于整数参数,pow() 的结果将是一个整数值,但是因为类型是 double ,所以除法也是 double 的。浮点除法(通常)会导致轻微错误的问题。以下更改可能会修复它。
((x-diferencia)/(int)pow(10,i))
关于c++ - 具有int变量乘法的int数组给出错误的结果c++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25477601/