C/C++题目--基本数据类型

博客探讨了C/C++中浮点数(如float)在内存中的表示与输出时的精度问题,解释了为何3.1在输出时显示为3.0999999。还讨论了整数的内存存储,特别是大小端字节序在解码整数值时的影响,并提到了嵌入式编程中常见数据类型u8、u16等的含义和使用目的。
摘要由CSDN通过智能技术生成

题目:一个float变量赋值为3.1时,为什么printf输出的值为3.0999999?(在VS环境下,输出为3.1000000)

【答案】

计算机是用二进制来表示浮点数和整数的。在十进制里,0.1是个简单、精确的小数,但是转换二进制表示却是循环小数0.0001100110011…。因此,3.2在十进制可以准确地表示,在二进制却不能。但二进制转换为十进制时,该数值便就不一致了。

题目:

double a,b;
//…
if(a==b)
{//是否相等。}

【答案】

不相等。

解决:

#include<math.h>

if((fabs(a-b)<=epsilon*fabs(a)))

题目:以下程序代码,输出结果是什么?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值