由条件可知表达式:x+a%3*(int)(x+y)%2/4的运算结果为2.5。
解答步骤如下:
x+a%3*(int)(x+y)%2/4
=2.5+7%3*(int)(2.5+4.7)%2/4 //将a,x,y的值带入
=2.5+1*7%2/4 //(int)(2.5+4.7)=(int)7.1=7
=2.5+7%2/4 //运算符优先级相同,按照从左到右进行计算
=2.5+1/4 //%为取余运算符,7除以2余数是1
=2.5 //1/4是两个整型相除,最后得到的类型也是整型0
程序运行结果如下图所示:
扩展资料:
这里面出现了强制数据类型转化精度损失的问题。对于上面float和double类型,都会存在精度损失。
精度损失产生的原因在于数据存储采用的都是2进制形式,二进制不能准确的表示1/10等分数,只能无限趋近。
对比float,double,BigDecimal的精度:
float:0.035000026
double:0.03500000000000003
BigDecimal use Double:0.03500000000000003108624468950438313186168670654296875
BigDecimal use String:0.035
总结:
1、float的精度损失最严重,然后依次是double,和使用参数类型为double的BigDecimal。
2、使用BigDecimal中参数为String类型的构造方法可以避免精度损失。
答案为2.5.
这个关键是优先级问题
1、括号永远优先级最高
2、无括号的默认优先级
* / 运算优先级最高
% 运算优先级次高
+ -运算优先级最低
所以是 2.5 + {7%[3*(x+y)]%(2/4)}
扩展资料:
优先级:
C语言中,运算符的运算优先级共分为15 级。1 级最高,15 级最低。 在表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符 优先级相同时,则按运算符的结合性所规定的结合方向处理。
优先级等级口诀
圆方括号、箭头一句号, 自增自减非反负、针强地址长度。
乘除,加减,再移位。
小等大等、等等不等。
八位与,七位异,六位或,五与,四或,三疑,二赋,一真逗。
参考资料来源:百度百科-C语言运算符
一共出现这么几个操作符:(),+,*,%,/,()
优先级顺序依次为:(分块),(强制类型转换),*,+,/,%,其中 / 和 % 优先级相同
所以运算的顺序应该是:
1.执行分块
(x+y) = 2.5 + 4.7 = 7.2;
2.执行强制转换
(int)7.2 = 7;
3.做乘法运算
3 * 7 = 21;
4.现在表达式变成了
x + a % 21 % 2 /4;
先做a % 21 % 2/4 = 7 % 21 % 2 / 4= 7 % 2/4 = 1 /4 = 0;
最后执行:x + 0 = 2.5 + 0 = 2.5;
(x+y) = 7.2
(int)(x+Y) = 7
a%3 = 1
a%3*(int)(x+y)%2/4 = 1*7%2/4 = 7%2/4 = 1/4 = 0(所有变量均是Int型)
x+0 = 2.5
(x+y) = 7.2
(int)(x+Y) = 7
a%3 = 1
a%3*(int)(x+y)%2/4 = 1*7%2/4 = 7%2/4 = 1/4 = 0(所有变量均是Int型)
(注意是float)
x+0 = 2.500000