1.(操作符)有如下代码:
int a = 5;
int b = (a++) + (--a) +(++a);
问执行完之后,b 的结果是多少?
2. (基本类型的运算)一家商场在举行打折促销,所有商品都进行8 折优惠。一
位程序员把这个逻辑写成:
short price = ...; // 先计算出原价
short realPrice = price * 8 / 10; //再计算出打折之后的价格
问:这段代码是否正确?如果正确,假设price 为100 ,那计算之后的
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的值。
答:
1、16;
2、不正确,因为其price为short类型,但是与8与10(默认为int型)再计算会转换为int型,但是realPrice为short型,且int比short数的范围更大,所以应该用强势转换类型使得其计算结果int型转换回short型,改后的代码为:
short price = 100; // 先计算出原价
short realPrice = (short) (price * 8 / 10); //再计算出打折之后的价格
且其计算结果为80;
3、
源代码如下:
package java_1028;
import java.util.Scanner;
public class java_1028_homework {
public static void main(String[] arges ){
Scanner in=new Scanner(System.in);
System.out.println("请输入您的五位彩票号码:");
int ticketNumber=in.nextInt();
byte a5=(byte)(ticketNumber/10000);
byte a4=(byte)((ticketNumber-a5*10000)/1000);
byte a3=(byte) ((ticketNumber-a5*10000-a4*1000)/100);
byte a2=(byte)((ticketNumber-a5*10000-a4*1000-a3*100)/10);
byte a1=(byte)(ticketNumber-a5*10000-a4*1000-a3*100-a2*10);
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));
}
}
执行效果图如下:
答:
1、第二行代码f1、f2的赋值应该在其数值后面加上f;
2、byte b3=129 此处数据溢出 byte数据类型最大值为127;
3、j=j+10;此处 j在定义时并没有进行数据的初始化;
4、i=i*0.1;此处i为int型乘以0.1(为double型),应该改为i=(int)(i*0.1);
5、char c=c1+c2-1; 此处c1、c2(为char型)与1(int型)进行预算,将转换为int型;
应修改为: char c=(char)(c1+c2-1);
6、float f4=f1+f2*0.1; 同理应修改为float f4=(float)(f1+f2*0.1);
7、long l1=8888888888;应该改为long l1=8888888888L;
8、byte b=b1-b2;应修改为:byte b=(byte)(b1-b2);