只使用处理I/O的printDigit方法,编写一种方法一输出任意的double型量(可以是负的)...

 


/**
* Question:只使用处理IO的printDigit函数,编写一个过程以输出任意double型量(可以为负)
* @author wulei
* 这道题我的理解是使用最基本的System.out.print输出double型变量,如果直接输出的话会是:-4.539872316111111E9
* 整个方法分成三部分:1、获取第一个字符判断double正负;2、处理整数部分;3、处理小数部分。
*/
public class PrintDigitTest {

public static void main(String[] args) {
output(-12345.6789);
}

static void output(double num){
//正负号
if(num < 0){}
System.out.print("-");

//整数
long digit = Math.abs((long)num);
if(digit < 1){
System.out.print("0");
}else{
printDigit(digit);
}

//小数点
System.out.print(".");

//小数部分
double decimal = Math.abs(num-(long) num); //取整使用(long)
if(decimal > 0){
printDigit(decimal);
}else{
System.out.print("0");
}
}


static void printDigit(double num){
if(num > 1){
printDigit((long)(num/10)); //不可遗漏long
System.out.print((long)(num%10)); //不可遗漏long
}else if(num > 0 && num < 1){
long digit = (long) (num*10);
System.out.print(digit);
printDigit(num*10 - digit);
}else if(num == 1){
System.out.print("1");
}
}


}


/*PS:Java中所有数字都是带符号的,没有unsigned,

int在java中是固定的32bits,表示的范围为-2^31到2^31-1
-2147483648到2147483647才是正确的! 10位

-----------------------------------------------------------------------------------------------
System.out.println(Integer.MAX_VALUE); //2的31次方-1,10个数位,正的20亿左右,用在钱上面不一定够
System.out.println(Integer.MIN_VALUE); //负的2的31次方

2147483647
-2147483648

-----------------------------------------------------------------------------------------------
System.out.println(Long.MAX_VALUE); //2的63次方-1, 19个数位,很大了,可放心用在钱上面
System.out.println(Long.MIN_VALUE); //负的2的63次方

9223372036854775807
-9223372036854775808
-----------------------------------------------------------------------------------------------
System.out.println(Float.MAX_VALUE); //2的128次方-1, 38个数位,比long多了一倍,这个主要用来做简单数学精确运算使用
System.out.println(Float.MIN_VALUE); //2的-149次方

3.4028235E38
1.4E-45
-----------------------------------------------------------------------------------------------
System.out.println(Double.MAX_VALUE); //2的1024次方-1,308个数位,是float数位的10倍,主要用来做复杂运算和天文运算
System.out.println(Double.MIN_VALUE); //2的-1024次方

1.7976931348623157E308
4.9E-324

-----------------------------------------------------------------------------------------------
int和long都是很循规蹈矩的符合2的n次方的说法,int是32位,long是64位,唯有float和double像两个淘气的小孩子让人会捉摸不透。

 

float和double的表示形式与int和long是不一样的,他们采用的是IEEE 754标准,这个标准可以这样理解:

(1)两者还是32位的,和int一样,最小值只是他们的精度,是正数,这是需要注意的。如果要取到他们负最大,在他们的最大值前加个符号就好了,如-Float.MAX_VALUE,就是float能表示的负的最大了。

(2)float从左到右,第一位是符号位,2-9位共8位表示整数位,2的8-1次方等于128,后面23位是表示小数的,所以最大值是2^128-1;

(3)double从左到右,第一位是符号位,2-12是共11位表示整数位,2的11-1次方等于1024。剩余20位表示小数,所以最大值是2^1024-1.

(4)如上面代码,当正的最大减去负的正最大,就产生了内存泄露。溢出的结果是不对的。

总结:int 和long,float和double的存储要分别对待.要取到实实在在的最大最小值,只需要取到最大值就行了。

来源:http://blog.csdn.net/u013905744/article/details/50997129
*/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值