当c的值不为0时,下列选项中能够将c的值赋给变量a, b的是( )。 A.c=b=a B.(a=c)||(b=c) C.(a=c)&&(b=c) D.a=c=b
时间: 2023-09-23 08:03:56 浏览: 130
选项 A 和 D 都能够将 `c` 的值赋给变量 `a` 和 `b`,因为它们都是依次将 `c` 的值赋给 `a` 和 `b`,所以它们是等价的。因此,选项 A 和 D 都是正确的。
选项 B 和 C 都不能将 `c` 的值赋给变量 `a` 和 `b`。选项 B 中使用了逻辑或运算符 `||`,当第一个操作数为真时,整个表达式的值为真,不会执行第二个操作数,所以 `b` 的值不会被赋为 `c` 的值。选项 C 中使用了逻辑与运算符 `&&`,当第一个操作数为假时,整个表达式的值为假,不会执行第二个操作数,所以 `b` 的值不会被赋为 `c` 的值。因此,选项 B 和 C 都是错误的。
相关问题
c语言中,有以下定义语句double a,b;int w long C; 若各变量已正确赋值,则下列选项中正确的表达式是______ 。 A a=a+b=b++ B.w%(int)a+b) C.(c+w)%(int)a D.w=a==b;
### 回答1:
选项 A a=a+b=b++ 是错误的,因为赋值运算符的优先级低于加法和后缀自增运算符,因此应该先计算 b++,再将其结果加到 a 上,但是 a=a+b 的结果并不是一个左值,无法把 b++ 的结果直接赋值给 a+b。
选项 B w%(int)a+b 是错误的,因为 a 是 double 类型,需要使用显式类型转换将其转换为 int 类型才能进行取余运算。
选项 C (c+w)%(int)a 是正确的,因为 c 是 long 类型,可以与 a 相加后再取余。
选项 D w=a==b 是错误的,因为相等运算符 == 的优先级低于赋值运算符 =,因此应该先计算 a==b,再将其结果赋值给 w。另外,a 和 b 的类型是 double,无法直接和 int 类型进行比较,需要使用显式类型转换将其转换为 int 类型才能进行比较。因此,正确的表达式应该是 w = (int)(a==b)。
### 回答2:
正确的表达式是D. w=a==b;
解析:
根据给出的定义语句,可以得知a和b是double类型变量,w是int类型变量,C是long类型变量。
选项A a=a b=b是错误的表达式,因为a和b已经在定义语句中正确赋值,不需要再次赋值。
选项B w%(int)a b 是错误的表达式,因为%(int)a是将a强制转换为int类型再进行求余运算,而w是int类型变量,两者不能相互求余运算。
选项C (c w)%(int)a 是错误的表达式,因为c和w在定义语句中未给出,无法确定其类型和赋值情况。
选项D w=a==b; 是正确的表达式,它使用了关系运算符==来比较a和b的值是否相等,结果将赋给w变量。因为w是int类型变量,所以正确的表达式是 D. w=a==b;。
### 回答3:
正确的表达式是 D. w=a==b;
根据定义语句,a和b是double类型的变量,w是int类型的变量。
选项A中的表达式`a=a b=b`是错误的,因为a和b已经被定义并赋值,无需再次赋值。
选项B中的表达式`w%(int)a b`是错误的,因为%是取模运算符,只能用于整数类型的操作数。
选项C中的表达式`(c w)%(int)a`是错误的,因为变量c并未在定义语句中出现。
选项D中的表达式`w=a==b`是正确的,它先判断a是否等于b,返回一个布尔值(1表示真,0表示假),然后将结果赋值给w。注意,C语言中的布尔值是用整数表示的,1表示真,0表示假。
有以下定义诸可double a,b;int w long C; 若各变量已正确赋值,则下列选项中正确的表达式是______ 。 A a=a+b=b++ B.w%(int)a+b) C.(c+w)%(int)a D.w=a==b;
正确的表达式是D。
A选项:a = a + b 是将b的值加到a上,而b++是先将b的值赋给a,再将b的值加1,两个操作没有直接关系,不符合语法。
B选项:w%(int)a+b中,int强制转换会将a的值转换为整型,但是a的值为double型,不符合语法。
C选项:(c+w)%(int)a中,变量c没有定义,不符合语法。
D选项:w=a==b中,先比较a和b是否相等,结果为true或false,再将结果赋给w,符合语法。
阅读全文