为什么会出现-0.00这样的情况呢?
本帖最后由 御笔剑客 于 2018-9-4 11:17 编辑这是浮点误差引起的吗?不是补码存储的0只有一个0吗?为什么会出现负0这种情况呢?
#include <bits/stdc++.h>
#define PI 4*atan(1.0)
using namespace std;
int main()
{
printf("%.2f\n",sin(-PI));
return 0;
}
什么情况??这是 printf("%0.2f", x-y) 之后的结果?
如果是的话,那么可能出现这样的结果
运算后加大的浮点误差。因此在比较浮点数的时候,不能用 if (x == y),而是 if (abs(x-y) < 1e-7) 因为浮点运算,见 2 楼 claws0n 发表于 2018-9-4 11:25
什么情况??这是 printf("%0.2f", x-y) 之后的结果?
如果是的话,那么可能出现这样的结果
运算后加大的 ...
补码不是只有一个0吗?因为误差截断了吗? 御笔剑客 发表于 2018-9-4 11:33
补码不是只有一个0吗?因为误差截断了吗?
浮点数……很难有真正等于零的情况 claws0n 发表于 2018-9-4 11:39
浮点数……很难有真正等于零的情况
我明白了,谢谢你了,printf截断了后面的非0值 这个程序的宏定义是什么意思啊 本帖最后由 feitianqu 于 2018-9-5 09:00 编辑
是360度的意思么o 是pai但是为啥要这样表示pai呢?
feitianqu 发表于 2018-9-5 08:51
是360度的意思么o 是pai但是为啥要这样表示pai呢?
这样定义的pi精度更准,因为atan 1 = PI/4,这是反三角函数,再乘以4就变成了PI
页:
[1]