由条件可知表达式: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类型的构造方法可以避免精度损失。
这个问题很简单的,* ,/,%,的优先级一样,所以遵循自作至右的原则来运算。
先看a%3*(int)(x+y)%2/4。a=7,所以a%7的值等于1,然后x+y=7.2,因为int型转换,转换后为7;1*7依然是7;7%2=1;1/4=0(因为都是整数)。X+0=X=2.5;
故结果为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
看了他们的回答,我觉得少了一点解释,对于初学者来说,应该是这样解释,%只能用于整数运算,所以它们的变量都是整数,所以才会有后面的1/4输出结果是0而不是0.25,答案并非x+0.25而是x+0=2.5
(x+y) = 7.2
(int)(x+y) = 7
a%3*(int)(x+y) = 1
a%3*(int)(x+y)%2/4 = 1%2/4 = 0/4 = 0(所有变量均是Int型)
x+0 = 2.5