Why does gcc compiler output pow(10,2) as 99 not 100?(为什么 gcc 编译器输出 pow(10,2) 为 99 而不是 100?)
问题描述
#include <iostream.h>
#include <math.h>
int main()
{
int j=2;
int output;
output=pow(10,j);
cout<<output;
return 0;
}
我将上述代码写入 gcc 12 编译器并得到了输出 99 而不是 100.在各种站点上搜索时我没有得到正确的原因.编译器有问题吗?
I wrote above code to gcc 12 compiler and got the output 99 instead 100. I don't get the valid reason while searching on various sites. Is there any compiler problem?
推荐答案
因为整数截断.pow()
返回一个浮点值,由于浮点运算,大概是~99.999...
;然而,由于整数截断,即使 99.999...
也会被截断为 99.
Because of integer truncation. pow()
returns a floating point value, and due to floating point arithmetic, it is probably ~ 99.999...
; however, due to integer truncation, even 99.999...
gets truncated down to 99.
这篇关于为什么 gcc 编译器输出 pow(10,2) 为 99 而不是 100?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么 gcc 编译器输出 pow(10,2) 为 99 而不是 100?
基础教程推荐
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01
- Windows Media Foundation 录制音频 2021-01-01
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01
- 从 std::cin 读取密码 2021-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01
- 使用从字符串中提取的参数调用函数 2022-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01