最近搞Struts2弄得有点头昏脑胀,第一个例子“HelloWorld”总不成功,有点郁闷。
想起前几天上cpld/fpga课时老师说得判断小数位数的例子,闲来无事用Java实现一下。顺便也在csdn上露露头。
思想:将小数作为字符串处理,获取小数点的位置。用字符串的长度减去小数点位置,再减去1,得到小数位数。
import java.io.*;
import java.util.*;
import java.util.regex.*;
public class GetBitsOfDecimal {
public static void main (String[] args) {
//获取键盘输入
String inStr="";
System.out.println("输入小数:");
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
try{
inStr=br.readLine();
}catch(Exception e){}
//正则表达式判断是否为小数
Pattern p=Pattern.compile("//d{1,}//.//d{1,}");
Matcher m=p.matcher(inStr);
boolean b=m.matches();
if(b){ //是小数则判断位数
//获取小数点的位置
int bitPos=inStr.indexOf(".");
//字符串总长度减去小数点位置,再减去1,就是小数位数
int numOfBits=inStr.length()-bitPos-1;
System.out.println("小数位数为: "+numOfBits);
}else{ //不是小数,给出错误提示信息
System.out.println("输入的不是小数");
}
}
}
另外,还有一种思想:
小数:d
小数强制转换成的整数:i
小数位数:n (n的初始值为1)
while((d-i)>0) {
d=d*10;
i=(int)d;
n++;
}
这种算法在小数末位为“0”,例如“1.10”时会判断出错。不知Java或其他语言中有没有解决方法。
程序不大,也不难,大师们见笑了,但写完后心情好多了。以后每当郁闷的时候就写段小程序。