1.(操作符)有如下代码:
int a = 5;
int b = (a++) + (--a) +(++a);
问执行完之后,b 的结果是多少?
b=16
2. (基本类型的运算)一家商场在举行打折促销,所有商品都进行8 折优惠。一
位程序员把这个逻辑写成:
short price = ...; // 先计算出原价
short realPrice = price * 8 / 10; //再计算出打折之后的价格
问:这段代码是否正确?如果正确,假设price 为100 ,那计算之后的
realPrice值为多少?如果不正确,应该怎么改正?
把完整代码写出来
不正确
80.0
float realPrice = (float)(price * 8 )/ 10;
System.out.println(realPrice);
3.关于运算符的作业
随机给出一个五位数的彩票号码(正整数),程序输出该彩票号码中的数字及相关信息
1)在主类的main方法中声明一个用于存放彩票号码的int型变量ticketNumber,以及
用于存放彩票号码中个位、十位、百位、千位和万位上数字的byte型变量a1、a2、a3、
a4和a5。
2)?依次求出ticketNumber中个位、十位、百位、千位和万位上的数字,并将这些数字依
次赋值给变量a1、a2、a3、a4和a5。
3)输出表达式a1+a2+a3-a4+a5的值。
4)输出表达式a1*a2*a3*a4*a5的值。
public class HomeWork {
public static void main(String[] args) {
int ticketNumber=12345;
byte a1,a2,a3,a4,a5;
a1=(byte)(ticketNumber%10);
a2=(byte)(ticketNumber%100/10);
a3=(byte)(ticketNumber%1000/100);
a4=(byte)(ticketNumber%10000/1000);
a5=(byte)(ticketNumber/10000);
System.out.println(a1+a2+a3+a4+a5);
System.out.println(a1*a2*a3*a4*a5);
}
}
(1)“j”没有赋初值,所以后面(4)、(11)处错误。
(2)“f1=0.1”后面没有加f,所以(9)、(10)错误。
(3)byte范围是-128到+127,数据溢出。
(5)在运算时数据会先转换成整形在运算,而i定义的是byte类型数据溢出。
(6)数据溢出
(7)没有强制转换,错同(5)。
(8)数据溢出