若定义x和y为double类型,则表达式:x=2
来源:学生作业帮助网 编辑:作业帮 时间:2024/05/17 04:38:15
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
2.000000再答:再答:再答:这里的3/2得的值是1,因为默认两个整形数相除得整形数,所以才会有1+3/2=2的结果。而定义的x,y是float浮点型,所以结果为2.000000
这涉及到C语言的一些规定第一就是自动向上转换:也就是说占用空间少的类型和占用空间多的类型运算,运算结果转换为占用空间多的类型(这是为了防止运算结果放在少空间发生溢出)int占用4个字节double占用
两个整数相除是整数,3/4=0;所以y=x=1.0;因为y是double型变量,所以,当然,这种表示不是惟一,如y=1.000000
答案:D首先就是参数问题,由题意可知,可排除A,C,在B和D中,就得看函数的返回值类型了,B中的返回值类型没有写,故C语言中,默认的就是int类型了.所以,返回值类型必须写为double,不能省略;其
y=1+3/2=2;再问:不是先乘除后加减吗?再答:是啊,3/2=1;(int值)1+1=2;
A正确的.B错=x/y/zC错=x/y/zD错=x/y/z