【问题标题】:Multiplication of float with int in c在c中将float与int相乘
【发布时间】:2013-07-12 12:28:14
【问题描述】:
#include <stdio.h>
int main(){
    float var = 0.612;
    printf("%f\n",var);
    printf("%f\n",var*100);
    return 0;
}

o/p

0.612000
61.199997

我发现对于 JavaScript,我们有 .tofixed() 方法。

我们如何在 C 中解决这个问题?

【问题讨论】:

    标签: c floating-point printf


    【解决方案1】:

    打印时可以指定精度:

    printf("%.3f\n", 100 * var);
    

    由于您所拥有的确切数字可能无法在 float 本身中表示,因此您无法对数字本身执行任何操作来“删除”小数,这完全取决于您如何选择呈现数据。

    【讨论】:

    • 对,但如果我们将float 替换为double,错误可能会缩小。
    • @phoenix 正如您在输出中显示的那样.6f 不应该显示`61.200000` 这就是答案.3f 的原因,确定您的精确位置,另外考虑glglgl 的建议。
    猜你喜欢
    • 1970-01-01
    • 2015-03-25
    • 2019-05-16
    • 1970-01-01
    • 1970-01-01
    • 2016-01-13
    • 1970-01-01
    • 2013-10-01
    • 2017-09-04
    相关资源
    最近更新 更多