c++ - 具有int变量乘法的int数组给出错误的结果c++

标签 c++ arrays

我正在学习自己的 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/

相关文章:

c++ - CMake 构建错误 - 虚拟方法错误缺少 vtable

c++ - float 和双重比较最有效的方法是什么?

c - 字符数组的 strlen 和大小

javascript - 本地存储在页面重新加载时不断重置

C:将数组(指针)传递给函数

java - 如何使用 Spring 的 RestTemplate 来 POST 一个字符串数组

c++ - 函数超出堆栈大小,考虑将一些数据移动到堆中 (C6262)

c++ - 使用 std::memcpy 复制包含 boost::any 数据成员的对象

c++ - 窗口显示后如何调用函数?

java - 在 Java 中,如何对排序字段深度为多层的对象 ArrayList 进行快速排序?