此问题已被问过几次,但所有答案都涉及 sprintf 或涉及手动删除尾随零。真的没有更好的办法吗?用 std::stringstream
是不可能实现的吗?
最佳答案
首先计算小数点前后有多少个可能的数字:
int digits_before = 1 + (int)floor(log10(fabs(value)));
int digits_after = std::numeric_limits<double>::digits10 - digits_before;
然后你找出这些数字中有多少是零:
double whole = floor(pow(10, digits_after) * fabs(value) + 0.5);
while (digits_after > 0 && (whole/10.0 - floor(whole/10.0)) < 0.05)
{
--digits_after;
whole = floor(whole / 10.0 + 0.5);
}
if (digits_after < 0) digits_after = 0;
现在您有了一个可以与 std::setprecision
一起使用的值:
std::stringstream ss;
ss << std::fixed << std::setprecision(digits_after) << value;
归根结底,这是大量的工作并且重复了字符串转换所做的工作,这就是为什么人们通常只转换为字符串并删除尾随零的原因。不,没有简单的格式化选项可以执行此操作,您必须以困难的方式进行或根本不进行。
查看上面的代码:http://ideone.com/HAk55Y
关于c++ - 使用定点表示法将 double 转换为字符串,没有尾随零且没有 sprintf,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22177656/