2 zhengylsc zhengylsc 于 2013.12.09 14:42 提问

望大神帮分析下,最好是把该代码的思路给分析讲解下,虽没有分但万分感谢!

import java.math.BigDecimal;

public class NumToRMB
{

public static void main(String[] args)
{
    System.out.println(changeToBig(Double.parseDouble(args[0])));
}

public static String changeToBig(double value)
{
    char[] hunit = {'拾', '佰', '仟' }; // 段内位置表示
    char[] vunit = {'万', '亿' }; // 段名表示
    char[] digit = {'零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示
    // long midVal = (long)(value*100); ////存在精度问题,如0.9->0.8999
    BigDecimal midVal = new BigDecimal(Math.round(value * 100)); // 转化成整形,替换上句
    String valStr = String.valueOf(midVal); // 转化成字符串
    String head = valStr.substring(0, valStr.length() - 2); // 取整数部分
    String rail = valStr.substring(valStr.length() - 2); // 取小数部分

    String prefix = ""; // 整数部分转化的结果
    String suffix = ""; // 小数部分转化的结果
    // 处理小数点后面的数
    if (rail.equals("00"))
    { // 如果小数部分为0
        suffix = "整";
    }
    else
    {
        suffix = digit[rail.charAt(0) - '0'] + "角"
                + digit[rail.charAt(1) - '0'] + "分"; // 否则把角分转化出来
    }
    // 处理小数点前面的数
    char[] chDig = head.toCharArray(); // 把整数部分转化成字符数组
    boolean preZero = false; // 标志当前位的上一位是否为有效0位(如万位的0对千位无效)
    byte zeroSerNum = 0; // 连续出现0的次数
    for (int i = 0; i < chDig.length; i++)
    { // 循环处理每个数字
        int idx = (chDig.length - i - 1) % 4; // 取段内位置
        System.out.print("idx:" + idx + ".." + (chDig.length - i - 1));
        int vidx = (chDig.length - i - 1) / 4; // 取段位置
        System.out.println("**vidx" + ".." + (chDig.length - i - 1)/4);
        if (chDig[i] == '0')
        { // 如果当前字符是0
            preZero = true;
            zeroSerNum++; // 连续0次数递增
            if (idx == 0 && vidx > 0 && zeroSerNum < 4)
            {
                prefix += vunit[vidx - 1];
                preZero = false; // 不管上一位是否为0,置为无效0位
            }
        }
        else
        {
            zeroSerNum = 0; // 连续0次数清零
            if (preZero)
            { // 上一位为有效0位
                prefix += digit[0]; // 只有在这地方用到'零'
                preZero = false;
            }
            prefix += digit[chDig[i]-'0']; // 转化该数字表示
            System.out.println(chDig[i]-'0');
            if (idx > 0)
                prefix += hunit[idx - 1];
            if (idx == 0 && vidx > 0)
            {
                prefix += vunit[vidx - 1]; // 段结束位置应该加上段名如万,亿
            }
        }
    }

    if (prefix.length() > 0)
        prefix += '圆'; // 如果整数部分存在,则有圆的字样
    return prefix + suffix; // 返回正确表示
}

}

1个回答

songzhiyong1121
songzhiyong1121   2013.12.09 15:31
已采纳

写的挺好,注释也很清楚啊,我是不是可以理解你这块儿不太懂呢

         int idx = (chDig.length - i - 1) % 4; // 数字处于哪位,然后映射到char[] hunit = { '拾', '佰', '仟' };的下标
        System.out.println("段位置-index:" + idx + ".." + (chDig.length - i - 1));
        int vidx = (chDig.length - i - 1) / 4; //同上,找到对应char[] vunit = { '万', '亿' };的下标
        System.out.println("段名-index" + ".." + (chDig.length - i - 1) / 4);

我改了一下注释,建议断点单步调试一遍,你就懂了

zhengylsc
zhengylsc 谢谢你啊
大约 4 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!