若已定义x和y为double类型,x=1,则表达式y=x 3 2的值是
来源:学生作业帮助网 编辑:作业帮 时间:2024/11/18 15:55:06
double是双精度浮点型,不是整型,双精度浮点型数,直观上就是小数的确应该是2.03/2的值是1x是double类型x+3/2自动转型为double类型所以是小数.再问:Ŷ
因为3和2都是int型的,所以认为3/2的结果也是int的,舍弃后面的尾数,仅留下整数位的1.然后加上double型的x,复制给double型的y所以是2.0
y=x+3/2=1.0+1=2.0=2.0000002.0或者2.000000都是一样的再问:为什么不是1.0+1.5再答:先计算3/2,3和2都是整型,这个算出来的值就是1,如果是3.0/2或者3/
c.2.0;因为,double是双精度的浮点型,但3/2=1,除非是3.0/2或者(double)3/2都=1.5,所以结果为2.0这种题型要自己上级多实践才能发现其中的奥妙,才能有很深的体会.
c.2.0;因为,double是双精度的浮点型,但3/2=1,除非是3.0/2或者(x的值为1.03/2等于1但要转换为1.0C因为x和y是实型
格式化输出若为%f(即printf(“%f”,y);),那么输出就为2.000000;格式化输出若为%d,输出就为0;若格式化输出为%3.1f,那么输出才为2.0;上面题目太不严密,希望你能真正搞懂哦
1楼正解.答案为B,具体过程为因为3和2都是int型的,所以3/2的值也为int型,即为1.然后由于y是double型,所以1又转化为double型的1,与x相加后赋值给y.
因为虽然x是1.00000000但是3和2都是整形啊,做除法的时候发生了截断哦,所以3/2不是1.5,而是1.所以y=2.0000000你这么写就对了3.0/2补充:2.0也是对的啊,没错.如果你在输
3/2向0取整.是1y=1+1类型自动转化.所以y为2.0
2.000000000再答:速度真快
两个整数相除取整数.y=x+3/2=1+1=2
x=1.0y=2.5
这涉及到C语言的一些规定第一就是自动向上转换:也就是说占用空间少的类型和占用空间多的类型运算,运算结果转换为占用空间多的类型(这是为了防止运算结果放在少空间发生溢出)int占用4个字节double占用
/运算符,先y除以2得到一个值,如果y的类型为int型,则取那个值的整数部分.如果是float、double型,最后的结果就为得到的那个值,不需取其整数部分了.x%2/2结果为0.5再取整,最后的结果
(double)x/y=2.0/4=0.5,后面的y%x=4%2=0;所以最终结果是0.5,祝好.
两个整数相除是整数,3/4=0;所以y=x=1.0;因为y是double型变量,所以,当然,这种表示不是惟一,如y=1.000000
y=1+3/2=2;再问:不是先乘除后加减吗?再答:是啊,3/2=1;(int值)1+1=2;
A正确的.B错=x/y/zC错=x/y/zD错=x/y/z