多於 12 位就暫不考慮了。
因此實現這個程式的關鍵就是把一個 4 位整數的浮點數轉換成一個中文讀法。下面程式把這個需求實現了一部分。import java.util.Arrays; import java.util.Scanner; public class NumRmb { private String[] hanArr = { "零", "壹", "貳", "叁", "肆", "伍", "陸", "柒", "捌", "玖" }; private String[] unitArr = { "十", "百", "千" }; private String[] unitArr2 = { "分", "角" }; /** * 把一個浮點數分解成整數部分和小數部分字串 * * @param num 需要被分解的浮點數 * @return 分解出來的整數部分和小數部分。第一個陣列元素是整數部分,笫二個陣列元素是小數部分 */ private String[] divide(double num) { // 將一個浮點數強制型別轉換為long型,即得到它的整數部分 long zheng = (long) num; // 浮點數減去整數部分,得到小數部分,小數部分乘以100後再取整得到2位小數 long xiao = Math.round((num - zheng) * 100); // 下面用了2種方法把整數轉換為字串 return new String[] { zheng + "", String.valueOf(xiao) }; } /** * 將數位轉成人民幣讀法 * * @param str[] 被分解成整數部分和小數部分的字串陣列 * @return 人民幣讀法的漢字字串 */ private String toHanStr(String str[]) { int zhengLen = str[0].trim().split("").length; // 整數的長度 int xiaoLen = str[1].split("").length; // 小數的長度 String result = ""; // 依次遍歷整數的每一位數位 for (int i = 0; i < zhengLen; i++) { // 把char型數位轉換成int型數位,3 種方法如下: // 方法1:因為它們的ASCII碼值恰好相差48,因此把char型數位減去48得到int型數位,例如‘4’被轉換成4 // int num = str[0].charAt(i) - 48; // 方法2:先將char型數位轉換為String字串,再用Integer(int的包裝類,提供了String轉換為int的方法,後面教學中我們會詳細講解)轉換為int型數位 // int num = Integer.parseInt(String.valueOf(str[0].charAt(i))); // 方法3:char型數位減去字元0來轉換為int型數位 int num = str[0].charAt(i) - '0'; // 如果不是最後一位數位,而且數位不是零,則需要新增單位(千、百、十) if (i != zhengLen - 1 && num != 0) { result += hanArr[num] + unitArr[zhengLen - 2 - i]; } else { // 否則新增“元” result += hanArr[num] + "元"; } } // 依次遍歷小數的每一位數位 for (int i = 0; i < xiaoLen; i++) { int num = str[1].charAt(i) - '0'; // 如果數位不是零,則需要新增單位(角,分) if (num != 0) { result += hanArr[num] + unitArr2[xiaoLen - 1 - i]; } } return result; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); NumRmb nr = new NumRmb(); System.out.println("請輸入一個浮點數:"); String num = sc.next(); String[] strs = nr.divide(Double.parseDouble(num)); System.out.println("分解成整數部分和小數部分結果為:" + Arrays.toString(strs)); System.out.println("人民幣讀法為:" + nr.toHanStr(strs)); } }從上面程式的執行結果來看,初步實現了所需功能,但這個程式並不是這麼簡單的,對零的處理比較複雜。例如,有兩個零連在一起時該如何處理呢?如果最高位是零如何處理呢?最低位是零又如何處理呢?因此,這個程式還需要繼續完善,希望讀者能把這個程式寫完。