前言
提示:哇,这道题我写了好久都没有写出来(果然是我太菜了),在csdn找到一个道友写的道友的源代码链接,然后根据自己的理解写了理解注释,
提示:以下是本篇文章正文内容,下面案例可供参考
一、代码如下
package bookRental;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Scanner;
//这道题我表示很头大,矩阵我也不会呀
public class text {
public static void main(String[] args){
Scanner scanner = new Scanner(System.in);
String number = scanner.nextLine();
scanner.close();
callNumber(number);
}
private static void callNumber(String text){
String result;
if(text.length() <= 4)//如果小于等于4位,也就是千位以内
{
result = lowerThan10000(text, true);
} else if(text.length() <= 8)//千万位以内
{
String n1 = text.substring(text.length() - 4, text.length());//substring返回一个字符串,该字符串是这个字符串的子字符串
String n2 = text.substring(0, text.length() - 4);
result = lowerThan10000(n2, true) + "wan ";//把千万位拆成千位算,然后在后面直接加上“wan”
result += lowerThan10000(n1, false);
} else {
String n1 = text.substring(text.length() - 4);//亿万位同理
String n2 = text.substring(text.length() - 8, text.length() - 4);
String n3 = text.substring(0, text.length() - 8);
result = lowerThan10000(n3, true) + "yi ";
result += lowerThan10000(n2, false) + "wan ";
result += lowerThan10000(n1, false);
}
System.out.println(result);
}
static String[] chineseNumbers = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu", "shi"};
static String[] groups = {"ge", "shi", "bai", "qian", "wan", "yi"};
private static String lowerThan10000(String text, boolean isStart){
int length = text.length();//查询输入数字长度
int number = Integer.parseInt(text);//将字符串转换为整形int
if(length <= 1)//如果长度小于等于1
{
return chineseNumbers[number] + " ";//返回一个“String[] chineseNumbers”数组对应的拼音和空字符串
}
else if(text.startsWith("1") && length == 2 && isStart)//以“1”开头并且 长度为2 并且是true
{
if(text.equals("10")) return "shi ";//如果text等于10,就直接返回shi
return "shi " + chineseNumbers[number % 10] + " ";//如果不等于10,就返回"shi"+整形数字%10的余数所对应的拼音
}
//上面这段处理简直牛逼极了,充满人性的关辉
int factor = (int) Math.pow(10, length - 1);//Math.pow(1,2)数值1的数值2次方//
int index = length - 1;//决定1后面有几个零
boolean isLastZero = false;
StringBuilder sBuilder = new StringBuilder();//使用StringBuilder有利于append和insert方法的使用
while (factor > 0)//几乎绝对正确,因为个位数和text.startsWith("1")在前面已经排除掉了,剩下>=20的数字,就说明factor最小等于10
{
if(number == 0)//这里是用于结束while循环用的,当求到最后number等于0时,就用
break;
int count = number / factor;//这里求这正串数字的第一个数,也就最大的那一位数
number -= factor * count;//这里求减去最大的那一位后面的数,用于下一轮while循环
factor/= 10;//求它是个几位数,太牛逼了这个算法,除到最后等于1时4-4number就会等于0,结束while循环(上面)
if(count == 0)//根据分数分母不为0的定理,只有分子有可能为0,有就是只有可能是number为0,但是前面已经排除了
{
if(!isLastZero) {
sBuilder.append(chineseNumbers[count]).append(" ");
}
isLastZero = true;
}
else{
sBuilder.append(chineseNumbers[count]).append(" ");//求出它最大的那一位数的拼音,并放在字符串的第一位
if(index > 0)//个位数前面已经排除过了,所以几乎为全正确
{
sBuilder.append(groups[index]).append(" ");//根据后面有几个零直接从数组里找相应的单位,这里简直绝了,一定对数字有细心的观察才能发现的规律
}
isLastZero = false;
}
index -= 1;//减少一个零,再求一遍while循环
}
return sBuilder.toString();//返回写好的字符串
}
}
总结
提示:注释都是我自己的理解,如有错误,欢迎各位道友指出。