C语言:!(x+y)+z-1 && y+z/2 跪求高手解答 不胜感激。 谢谢!!

如题所述

算数运算符优先于逻辑运算符

先算(x+y),再算(x+y)-z,再算(x+y)-z-1。

若(x+y)-z-1的结果为非零数,则!(x+y)-z-1的值为0。

(x+y)-z-1的值为0,则!(x+y)-z-1的值为1。

先算z/2,再算y+z/2。

若y+z/2的值为0,那么整个表达式的值为0。

若左边(x+y)-z-1的结果为1 ,y+z/2的结果非零值,那么整个表达式的结果为1。

其他情况,&&左右两边出现一个零,则整个表达式的结果为0。

扩展资料:

运算符与优先级:

优先级与求值顺序无关。如a+b && b*c,虽然*优先级最高,但这个表达式求值顺序是从左到右。

优先级从上到下依次递减,最上面具有最高的优先级,逗号操作符具有最低的优先级。

相同优先级中,按结合性进行结合。大多数运算符结合性是从左到右,只有三个优先级是从右至左结合的,它们是单目运算符、条件运算符、赋值运算符。

基本的优先级需要记住:

指针最优,单目运算优于双目运算。如正负号

先算术运算,后移位运算,最后位运算。请特别注意:1 << 3 + 2 & 7等价于 (1 << (3 + 2))&7.

逻辑运算最后结合。

参考资料来源:百度百科-运算符优先级

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-12-16
这个语句大部分是用在if()里面当作条件表达式的,因为C语言没有真正意义的BOOL类型,而是定义了 0 为 FALSE, 非 0 为TRUE,所以条件表达式可以是算术表达式

先计算 (x+y) 再取 非 (这里注意,任何非零的值取非,结果是0, 但是 0 取非,值为1,这是C语言定义的), 值再 +z -1 , 结果如果为零,则不 执行 && 后面的 y+z/2, 因为 0&&任意值 都是 0 即为 FALSE,只有在 && 前面为 TRUE的时候才会去执行 && 后面的语句

这里考查的是 运算符的优先级,以及 && 的细节,如果是考试中的话可能会出现 x++ && x++ 或者 x++ || x++ 然后问x的值 之类问题追问

若定义: int x=3,y=4,z=5; 那么表达式 !(x+y)+z-1&&y+z/2的值?? 答案为 1 你的回答非常好

本回答被提问者采纳
第2个回答  2011-07-20
参考人家的,这种题知道运算优先级就万事ok了

1级优先级 左结合
() 圆括号
[] 下标运算符
-> 指向结构体成员运算符
. 结构体成员运算符
2级优先级 右结合
! 逻辑非运算符
~ 按位取反运算符
++ 前缀增量运算符
-- 前缀增量运算符
+ 正号运算符
- 负号运算符
(类型) 类型转换运算符
* 指针运算符
& 地址与运算符
sizeof 长度运算符
3级优先级 左结合
* 乘法运算符
/ 除法运算符
% 取余运算符
4级优先级 左结合
+ 加法运算符
- 减法运算符
5级优先级 左结合
<< 左移运算符
>> 右移运算符
6级优先级 左结合
<、<=、>、>= 关系运算符
7级优先级 左结合
== 等于运算符
!= 不等于运算符
8级优先级 左结合
& 按位与运算符
9级优先级 左结合
^ 按位异或运算符
10级优先级 左结合
| 按位或运算符
11级优先级 左结合
&& 逻辑与运算符
12级优先级 左结合
|| 逻辑或运算符
13级优先级 右结合
? : 条件运算符
14级优先级 右结合
= += -= *= /= %= &= ^= |= <<= >>= 全为赋值运算符
15级优先级 左结合
, 逗号运算符
优先级从上到下依次递减,最上面具有最高的优先级,逗号操作符具有最低的优先级。
所有的优先级中,只有三个优先级是从右至左结合的,它们是单目运算符、条件运算符、赋值运算符。其它的都是从左至右结合。
具有最高优先级的其实并不算是真正的运算符,它们算是一类特殊的操作。()是与函数相关,[]与数组相关,而->及.是取结构成员。
其次是单目运算符,所有的单目运算符具有相同的优先级,因此在我认为的 真正的运算符中它们具有最高的优先级,又由于它们都是从右至左结合的,因此*p++与*(p++)等效是毫无疑问的。
另外在C语言里 没有前置后置之分 因为++ -- 是右结合所以 右侧优先运算 表现为 "后置优先级比较高" 的假象 前置和后置的区分是因为运算符重载而后加入C++的
接下来是算术运算符,*、/、%的优先级当然比+、-高了。
移位运算符紧随其后。
其次的关系运算符中,< <= > >=要比 == !=高一个级别,不大好理解。
所有的逻辑操作符都具有不同的优先级(单目运算符出外,!和~)
逻辑位操作符的"与"比"或"高,而"异或"则在它们之间。
跟在其后的&&比||高。
接下来的是条件运算符,赋值运算符及逗号运算符。
在C语言中,只有4个运算符规定了运算方向,它们是&&、| |、条件运算符及赋值运算符。
&&、| |都是先计算左边表达式的值,当左边表达式的值能确定整个表达式的值时,就不再计算右边表达式的值。如 a = 0 && b; &&运算符的左边位0,则右边表达式b就不再判断。
在条件运算符中。如a?b:c;先判断a的值,再根据a的值对b或c之中的一个进行求值。
赋值表达式则规定先对右边的表达式求值,因此使 a = b = c = 6;成为可能。
第3个回答  2011-07-20
!(((x + y )+ z - 1)&& (y + (z / 2)))
第4个回答  2011-07-20
x,y,z,的数值是多少啊。

C语言:!(x+y)+z-1 && y+z\/2 跪求高手解答 不胜感激。 谢谢!!
先算z\/2,再算y+z\/2。若y+z\/2的值为0,那么整个表达式的值为0。若左边(x+y)-z-1的结果为1 ,y+z\/2的结果非零值,那么整个表达式的结果为1。其他情况,&&左右两边出现一个零,则整个表达式的结果为0。

n=!(x+y)+z-1&&y+z\/2;
这个属于逻辑运算,逻辑运算时非零的数为真即为1 !(x+y)=0,(z-1)=1所以 !(x+y)+z-1=1 y+z\/2=1 1和1做与运算的1,所以结果为1,n=1

...x=3,y=4,z=5;则表达式 !(x+y)+z-1&&y+z\/2的值是
答案是1。涉及到的运算符: ! () + - && \/ 运算符优先级为:() ! \/ + - && 运算过程:x=3,y=4,z=5 !(x+y)+z-1&&y+z\/2 !(3+4)+5-1&&4+5\/2 所以表达式计算步骤为 !(3+4)+5-1&&4+5\/2 -> !7+5-1&&4+5\/2 !7为 0 -> 0+5-1&&4+5\/2 5\/2 整数除整数...

...x=3,y=4,z=5;,则表达式!(x+y)+z-1&&y+z\/2的值为,求详细解
所以表达式可以写成这种形式:(!(x+y)+z-1)&&(y+z\/2)。计算顺序为:!(x+y)+z-1 = !7 + 5 - 1 = 0 + 5 - 1 = 4 y+z\/2 = 4 + 5/2 = 4 + 2 = 6 4&&6 = 1 所以最后结果为1.在VC6.0下运行结果如下图:...

int x=3,y=4,z=5;则表达式!(x+y)+z-1&&y+z\/2的值是 A 6 B 0 C 2 D 1
C++中答案是D 1 因为按运算符优先级先算(),再算!,接着\/,然后+ -,最后&& 就等于算 【!(x+y)+z-1】&&【y+z\/2】=1 谢谢。

c语言考试,求答案,急!!急!!
(21) 已有定义:int x=3,y=4,z=5;,则表达式!(x+y)+z-1 && y+z\/2的值是( )。 A) 6 B) 0 C) 2 D) 1 (22) 有一函数, ,以下程序段中不能根据x值正确计算出y值的是( )。 A) if(x>0) y=1; B) y=0; else if(x==0) y=0; if(x>0) y=1; else y=-1; else if...

...x=3,y=4,z=5 则表达式!(x+y)+z-1&&y+z\/2的值是,这个怎样求,想要具 ...
!(x+y)+z-1&&y+z\/2 =!(3+4)+5-1&&4+5\/2 =!7+5-1&&4+5\/2 =0+4&&4+5\/2 =4&&6 =1 运算符的优先级:()最高,下来是!下来是+,-,*,\/,最后是&& 逻辑与在左边右边只要有一个0的时候结果就为0 4和6都不为0,所以结果为1 参考资料:百度一下 ...

!(x+y)-1&&y+z\/2是什么意思
这个应该是计算机代码,!(x+y)-1&&y+z\/2用于判断"对"与"错".结果两种,true or false !(x+y)-1&&y+z\/2 中x,y,z应该有一个赋值,左右都成立或都不成立则为true ,一个成立一个不成立则为false.多数情况下,这种格式会出现在C,C+,C#的语法中.java也有但略有不同\/ 希望对你有帮助~!

计算机考试试卷题库的题目类型都有什么?
C) 6,4 D) 7,4(21) 已有定义:int x=3,y=4,z=5;,则表达式!(x+y)+z-1 && y+z\/2的值是( )。A) 6 B) 0 C) 2 D) 1(22) 有一函数, ,以下程序段中不能根据x值正确计算出y值的是( )。A) if(x>0) y=1; B) y=0; else if(x==0) y=0; if(x>0) y=1; else y=-1...

...学校网站上提交提示Time Limit Exceed,不胜感激!
先用厄拉多塞筛法计算 1 ~ 10000 中所有的质数,保存在一个数组里面。然后用得到的素数数组判断输入的数是否满足D-Prime 的条件。

相似回答