您的位置:首页 > 编程语言 > Java开发

吉软-java57-第二次作业

2017-10-28 00:00 411 查看
图:说出下面程序片段中编译错误或可能产生计算溢出的部分。



float f1=0.1; float f2=123; // 0.1后需要跟上f

long l1 = 12345678, l2 = 8888888888; // l2数值后面均加上L

byte b1 = 1,b2 = 2,b3 = 129; // 129超出byte的范围

j = j+10; // j未赋值,所以无法使用

i = i*0.1; // 0.1默认为double型,计算时转为int型,需要强制转换

byte b = b1 - b2; // b1 b2 此时为int型,需要强制转换为byte型

char c = c1 + c2 - 1; //int到char需要强制转换

float f4 = f1+f2*0.1; //0.1是double型

1.(操作符)有如下代码:
int a = 5;
int b = (a++) + (--a) +(++a);
问执行完之后,b 的结果是多少?

5+5+6=16

2. (基本类型的运算)一家商场在举行打折促销,所有商品都进行8 折优惠。一
位程序员把这个逻辑写成:
short price = ...; // 先计算出原价
short realPrice = price * 8 / 10; //再计算出打折之后的价格
问:这段代码是否正确?如果正确,假设price 为100 ,那计算之后的
realPrice值为多少?如果不正确,应该怎么改正?
把完整代码写出来;

不正确 题中说明price为100,所以用short来接收打折后的数据最合理。

public class CuXiao{

public static void main(String[] args){

short price = 100;

short realPrice =(short) price * 8 / 10;

}

}

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的值。

package li;
import java.util.Random;
public class LianXi {
public static void main(String[] args) {
System.out.println("随机彩票号码为:");
Random SuiJi = new Random();
int ticketNumber = SuiJi.nextInt(90000) + 10000;
System.out.println(ticketNumber);

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);
System.out.println(a1*a2*a3*a4*a5);
}
}

运行结果:



注:该处生成的是随机数,且范围在10000~99999;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: