发布网友 发布时间:2022-04-25 08:45
共5个回答
热心网友 时间:2023-11-10 04:29
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接
热心网友 时间:2023-11-10 04:30
double d = 0D;
热心网友 时间:2023-11-10 04:30
这样可以吧,转成int
热心网友 时间:2023-11-10 04:31
double a = 0.0;热心网友 时间:2023-11-10 04:32
double? 直接 a ==0 判断追问不对
热心网友 时间:2023-12-02 05:27
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接
热心网友 时间:2023-12-02 05:27
double d = 0D;
热心网友 时间:2023-12-02 05:28
这样可以吧,转成int
热心网友 时间:2023-12-02 05:28
double a = 0.0;热心网友 时间:2023-12-02 05:29
double? 直接 a ==0 判断追问不对
热心网友 时间:2023-11-10 04:29
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接
热心网友 时间:2023-11-10 04:29
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接
热心网友 时间:2023-11-10 04:29
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接
热心网友 时间:2023-11-10 04:30
double d = 0D;
热心网友 时间:2023-11-10 04:30
double d = 0D;
热心网友 时间:2023-11-10 04:30
这样可以吧,转成int
热心网友 时间:2023-11-10 04:31
double a = 0.0;热心网友 时间:2023-11-10 04:32
double? 直接 a ==0 判断追问不对
热心网友 时间:2023-11-10 04:30
double d = 0D;
热心网友 时间:2023-11-10 04:29
首先一个 double 是否为 0,或者其他的数值,是精确的,可以使用== 。
比如 double f = 0; 此时 f 是精确为 0 ,f == 0 为 true。
但是,double 在运算中,由于截尾的原因,总是有误差的。而此时是否为0,要看你的这个运算的精度要求。
比如运算后,f = 0.001,此时不能简单去和 0 比较,而是去和你的规定精度比较,比如你的精度要求是0.000001,则认为 f 值不为0,若精度为0.01,则认为 f 就等于0
可以这样 if(abs(f) < 精度0.000001) 执行 f 等于0时的操作
答案来自csdn各楼解答综合 网页链接