最近搞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或其他語言中有沒有解決方法。
程式不大,也不難,大師們見笑了,但寫完後心情好多了。以後每當郁悶的時候就寫段小程式。