- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想知道标准中是否有一些东西,比如 #define
或 numeric_limits
中的东西,它会告诉我 base-10 数字的最大数量浮点类型的组成部分。
例如,如果我有一些浮点类型,其最大值是:1234.567。我想要标准中定义的东西,它会告诉我该类型为 4。
我可以选择这样做吗?
template <typename T>
constexpr auto integral_digits10 = static_cast<int>(log10(numeric_limits<T>::max())) + 1;
最佳答案
正如 Nathan Oliver 在评论中指出的那样,C++ 提供了 std::numeric_limits<T>::digits10
.
the number of base-10 digits that can be represented by the type
T
without change, that is, any number with this many decimal digits can be converted to a value of typeT
and back to decimal form, without change due to rounding or overflow. For base-radix
types, it is the value ofdigits
(digits
-1 for floating-point types) multiplied by log10(radix
) and rounded down.
对此的解释是explained by Rick Regan here .总而言之,如果您的二进制浮点格式可以在有效数中存储 b 位,那么您保证能够往返最多 d 个十进制数字,其中 < em>d 是满足以下条件的最大整数
10d < 2b-1
在 IEEE754 binary64 的情况下(如今大多数系统上 C++ 中的标准 double
),则 b = 53,并且 2b-1 = 4,503,599,627,370,496,因此格式只保证能够表示 d = 15 位数字。
然而,这个结果适用于所有 位,而您只询问整数部分。然而,我们可以通过选择 x = 2b+1 轻松找到反例,这是不能用以下格式表示的最小整数:for binary64这是 9,007,199,254,740,993,它也恰好有 16 位数字,因此 will need to be rounded .
关于c++ - float 的整数部分中的 10 进制数字的最大位数是多少,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39776532/
需要帮助将这些给定的数字打印成星号,但我是编程新手;我该怎么做? #include int main(void) { int a[5]={20,1,5,15,12}; int i=0
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我不知道制服在内存中是如何表示的。 制服似乎会占用宝贵的寄存器空间,但它们最终会传入/通过/传出到全局内存中,对吗? 制服不用时情况会发生变化吗?编译器可以将它们优化掉吗?--在这种情况下,我已经将无
我正在尝试在名为“timeclock”的模型上记录“time_in”和“time_out”记录。这是我想做但无法开始工作的事情! 检查最后一个时钟条目,看看它是否同时填充了“time_in”和“tim
我想听听您如何解决这种编程任务!?每种类型(OPER = 1 类型)对应一种特定的信息。 这只是大约 10 个具有相同结构的规范之一。首选创建这些“转换器”(协议(protocol))的通用方法。 最
我正在使用 Rest API(NodeJS、Express)和 PostgreSQL 制作 React-Native 应用。 在我的本地机器上托管时一切正常。当 API 托管在我的机器上并且 Post
我是一名优秀的程序员,十分优秀!