ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

减少C中Double的数字

2019-09-01 17:05:37  阅读:299  来源: 互联网

标签:digit c function precision double


我需要一个降低双打精度(位数)的函数.

我需要它进行计算,而不是屏幕上的输出.

到目前为止,我所拥有的是:

double setDigits(double _number, int _digits)
{
    double tenth = pow((double)10,_digits);
    _number *= tenth;
    _number = floor(_number);
    _number /= tenth;

    return _number;
}

调用setDigits(sqrt(2),3)给出1.4139999999999999,而不是我想要的1.414.

我能做什么?

解决方法:

What can I do?

不幸的是,根本问题没有:在你的平台上,1.414没有精确的双重表示.您无法使用“1.414”运行计算,因为您不能在“双精度”中的任何位置放置“1.414”.

参见例如http://www3.ntu.edu.sg/home/ehchua/programming/java/DataRepresentation.html.

您可以做的是保持最大精度的数字,并以较低的精度显示它.您需要计算机器精度并在计算过程中跟踪误差.

所以你将使用1.413999999999997,最后得到答案,比如41.99999137;您将与之一起展示

printf("The answer is %.3f\n", theAnswer);

或者您可以更改平台(编译器,数学库或浮点表示,例如在支持的地方使用long double),但请记住,您可以以获得的价格获得1.414,比如1.873错误(将其设为1.87299999999或1.87300000001),计算会有或多或少相同的错误.

您可以使用整数运算,将初始数乘以1,000,000(并获得1414000)或其他合适的比例,然后在结尾处进行除法.但是,整数具有最大限度.

还有任意精度库,它们使用不同的内部表示,允许您以所需的方式指定精度,例如GMP(http://gmplib.org/).当然,使用它比指定更困难

op1 = 6.0;
op2 = 7.0;
theAnswer = op1 * op2;

并且处理速度也较慢,但结果很好 – 或者说你说的好.

标签:digit,c,function,precision,double
来源: https://codeday.me/bug/20190901/1784731.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有