C语言 B,C选项错误的原因(答案是D) 有变量定义:floatk=2.0; 则下列合法的表达式是( ).(A) k%3 (B)k+7=8 (C) k++ (D) k=3,2+4,7
问题描述:
C语言 B,C选项错误的原因(答案是D)
有变量定义:floatk=2.0; 则下列合法的表达式是( ).
(A) k%3 (B)k+7=8 (C) k++ (D) k=3,2+4,7
答
a.错误原因是“%”是求余运算符,只能用于int型,比如int k=30,k%4的结果是2.本题中k是float,不能进行求余运算.
b.错误原因:“=”是赋值运算符,赋值运算符的左边必须是一个变量而不是一个值,k+7是一个表达式,其本质上是一个值而非变量,因此不能置于赋值表达式的左边.如果使用"=="则是合法的表达式,表示判断“k+7”是否与“8”相等.
c.错误的原因同a,“++”表达式表示将变量的值增加一,只能用于int类型
d.逗号表达式的值等于构成逗号表达式的最后一个表达式的值,本题中"3,2+4,7"的值即最后一个表达式7的值.将一个整型数赋值给一个float型会将其先强制转换为float,然后赋值.因此d选项是合法的表达式.