每日蓝桥- 基础练习 数的读法


前言

提示:哇,这道题我写了好久都没有写出来(果然是我太菜了),在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();//返回写好的字符串
    }
}




总结

提示:注释都是我自己的理解,如有错误,欢迎各位道友指出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值