C语言 B,C选项错误的原因(答案是D) 有变量定义:floatk=2.0; 则下列合法的表达式是( ).(A) k%3 (B)k+7=8   (C) k++ (D) k=3,2+4,7

来源:学生作业帮助网 编辑:作业帮 时间:2024/11/24 10:43:04
C语言 B,C选项错误的原因(答案是D) 有变量定义:floatk=2.0; 则下列合法的表达式是( ).(A) k%3 (B)k+7=8   (C) k++ (D) k=3,2+4,7
xՓjA_ek0U1/b ŒJRmx[K""KBRm? =X| Kaa̜@,hcemC;_>i^-w󬮳Ron%VM\ &VOhЧmQ^&fEj2)r b hhJԽxv7?cx°g-S?zũz%7 ?F4 &@W 1"]oQiGuE@?X >U;vDnE=PSQO?AzLR[8k]KLtc8@LLKiia[Z+3M Zܶy8쳚CSݦOz F{ 2o`]Dś#7. tljɻ˱|5 +7dc6j[o*C_4w(ljqXS#f

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

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选项是合法的表达式.