御笔剑客 发表于 2018-9-4 10:56:38

为什么会出现-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;
}

claws0n 发表于 2018-9-4 11:25:28

什么情况??这是 printf("%0.2f", x-y) 之后的结果?
如果是的话,那么可能出现这样的结果
运算后加大的浮点误差。因此在比较浮点数的时候,不能用 if (x == y),而是 if (abs(x-y) < 1e-7)

claws0n 发表于 2018-9-4 11:30:58

因为浮点运算,见 2 楼

御笔剑客 发表于 2018-9-4 11:33:56

claws0n 发表于 2018-9-4 11:25
什么情况??这是 printf("%0.2f", x-y) 之后的结果?
如果是的话,那么可能出现这样的结果
运算后加大的 ...

补码不是只有一个0吗?因为误差截断了吗?

claws0n 发表于 2018-9-4 11:39:54

御笔剑客 发表于 2018-9-4 11:33
补码不是只有一个0吗?因为误差截断了吗?

浮点数……很难有真正等于零的情况

御笔剑客 发表于 2018-9-4 11:51:25

claws0n 发表于 2018-9-4 11:39
浮点数……很难有真正等于零的情况

我明白了,谢谢你了,printf截断了后面的非0值

feitianqu 发表于 2018-9-5 08:50:31

这个程序的宏定义是什么意思啊

feitianqu 发表于 2018-9-5 08:51:45

本帖最后由 feitianqu 于 2018-9-5 09:00 编辑

是360度的意思么o 是pai但是为啥要这样表示pai呢?

御笔剑客 发表于 2018-9-5 09:08:46

feitianqu 发表于 2018-9-5 08:51
是360度的意思么o 是pai但是为啥要这样表示pai呢?

这样定义的pi精度更准,因为atan 1 = PI/4,这是反三角函数,再乘以4就变成了PI
页: [1]
查看完整版本: 为什么会出现-0.00这样的情况呢?