C语言:若已定义X和Y为double型,则表达式:x=1,y=x+3/2的值是2.0
本题就是将表达式的各数据均转换为double型,再进行运算。转换成double型后有啥不同?为啥值不是2?...
本题就是将表达式的各数据均转换为double型,再进行运算。
转换成double型后有啥不同?为啥值不是2? 展开
转换成double型后有啥不同?为啥值不是2? 展开
6个回答
推荐于2018-02-28
展开全部
1.x=1,,1是int类型,赋值给double的X的时候自动提升为double类型, 所以x=1.0(注意1.0是double类型的)。
2.3/2的结果是int的1,然后double的 x加上int的1,先会吧int的1提升为double的1.0,然后x+1.0=2.0(2.0为double类型的)。
2.3/2的结果是int的1,然后double的 x加上int的1,先会吧int的1提升为double的1.0,然后x+1.0=2.0(2.0为double类型的)。
展开全部
因为3和2都是int型的,所以认为3/2的结果也是int的,舍弃后面的尾数,仅留下整数位的1.然后加上double型的x,复制给double型的y所以是2.0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
2是整型(int)数,2.0是浮点(float或double)数,整型数没有小数,浮点型数带有小数。你的定义X,Y都是浮点数,计算时,编译器会先把输入的整型数自动转换成double型,然后在计算。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-11-23
展开全部
如果定义为int型(整型)是定义整数的 值就为2
double型(浮点型)是定义实数的 被定义过的y值只能是2.0
doudle型定义的范围大于int型
double型(浮点型)是定义实数的 被定义过的y值只能是2.0
doudle型定义的范围大于int型
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-11-23
展开全部
好像float 和 double 这样计算的结果都会 带.0要是 int 就不会有
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询