一、说出程序编译错误或可能产生溢出的部分
public class method{
public static void main(String[] args){
int i=1,j;
float f1=0.1;float f2=123; //float型后面必须加f
long l1= 12345678,l2=888888888;
double d1= 2e20,d2=124;
byte b1= 1,b2=2,b3=129; //b3 129溢出
j=j+10; //j没有赋初值
i=i/10;
i=i*0.1; //i是int型
char c1='a',c2=125;
byte b =b1-b2; //b是byte型,计算后默认是int,必须转换一下
char c=c1+c2-1;//c是char型,计算后默认是int,必须转换一下
float f3 =f1+f2;
float f4= f1+f2*0.1;//计算后默认是double,需要转换
double d=d1*i+j;//j没有赋初值
float f =(float)(d1*5+d2);
}
}
二、(操作符)有如下代码:
int a = 5;
int b = (a++) + (--a) +(++a);
问执行完之后,b 的结果是多少?
b=5+5+6=16;
三、(基本类型的运算)一家商场在举行打折促销,所有商品都进行8 折优惠。一
位程序员把这个逻辑写成:
short price = ...; // 先计算出原价
short realPrice = price * 8 / 10; //再计算出打折之后的价格
问:这段代码是否正确?如果正确,假设price 为100 ,那计算之后的
realPrice值为多少?如果不正确,应该怎么改正?
public class DataPrice{
public static void main(String[] args){
double price=100;
double realPrice = price * 8 /10;
System.out.println(realPrice);
}
}
四、关于运算符的作业
随机给出一个五位数的彩票号码(正整数),程序输出该彩票号码中的数字及相关信息
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 CaiPiao{
public static void main(String[] args){
int ticketNumber =(int)(10000+Math.random()*(99999-10000+1));
byte a1,a2,a3,a4,a5;
a1=(byte)(ticketNumber/10000);
a2=(byte)(ticketNumber%10000/1000);
a3=(byte)(ticketNumber%1000/100);
a4=(byte)(ticketNumber%100/10);
a5=(byte)(ticketNumber%10);
System.out.println(a1+" "+a2+" "+a3+" "+a4+" "+a5);
System.out.println("a1+a2+a3-a4+a5="+ (a1+a2+a3-a4+a5));
System.out.println("a1*a2*a3*a4*a5="+(a1*a2*a3*a4*a5));
System.out.println(ticketNumber);
}
}