C语言:已有声明int x=5,y;float z=2;,则下列表达式正确的是

问题描述:

C语言:已有声明int x=5,y;float z=2;,则下列表达式正确的是
A:y=x%z
B:x>0?y=x:y=-x
C.y=x/2=z
D.y=x=z/2
我觉得每个都对啊,为什么只有D是对的?

我对你题目及问题分析下,不对之处还清指出:
A:是求余,所以Z不能是小数,虽然z貌似是等于2,但是在定义的时候z是float内容,编译器会议float的存储方式储存,所以属于小数.
B:正确格式为:x > 0 ? (y = x):(y = -x);
C:从左至右开始计算,y = x / 2 再 x/2 = z;后面的部分出错了,x/2 = 2,2 = z,好像是对的,不过常量不能作为左值,所以错误.
D:就不说了,你都知道D是对的了.谭浩强书上103页有个例子是a>b?a:b+1相当于a>b?a:(b+1),这样的话我觉得B是不需要括号的。赋值号是自右向左开始计算的,按你这么说,D不是也应该是错的吗你好!首先我来回答你的第一个疑问,这涉及到C语言运算符的优先级的问题,在:和+号中:的优先级比+号高,所以先运行判断,再进行选择,而=和:的符号优先级是=比:高,当经历?号的判断后,由于=比:优先级高,所以得运行=的运算,这就产生了一个编译器能识别的错误,所以会报错。现在来回答第二个疑问,赋值号也就是=号,是将右边的值赋给左边,C中X/2是2,是一个数值,然后就相当于y = 2 = z;2右怎么能被赋值z呢?再次你所说到的D的问题,相当于 y = x = 1;说的明白一点就是,=号左边得一定是一个存储空间,而右边可以是一个存储空间内容,也可以是一个数值,这样,=运算就是将右边的数值写入=左边得存储空间里面,答案c中2 = z,是给一个数值赋值,D的话,你都知道他是对的就不说了。