日期:2014-05-20  浏览次数:20785 次

一个面试题,该怎么做
把数字转换成大写中文,题目上说明在某些财务软件会用到,因此还需要判断位数。

例如“123”要变成“壹百贰十弎”



------解决方案--------------------
网上抄的方法,没试过是不是正确,参考一下吧.
Java code

/**
     * 人民币转成大写
     * 
     * @param value
     * @return String
     */
    public static String hangeToBig(double value)
    {
        char[] hunit = { '拾', '佰', '仟' }; // 段内位置表示
        char[] vunit = { '万', '亿' }; // 段名表示
        char[] digit = { '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示
        long midVal = (long) (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(); // 把整数部分转化成字符数组
        char zero = '0'; // 标志'0'表示出现过0
        byte zeroSerNum = 0; // 连续出现0的次数
        for (int i = 0; i < chDig.length; i++)
        { // 循环处理每个数字
            int idx = (chDig.length - i - 1) % 4; // 取段内位置
            int vidx = (chDig.length - i - 1) / 4; // 取段位置
            if (chDig[i] == '0')
            { // 如果当前字符是0
                zeroSerNum++; // 连续0次数递增
                if (zero == '0')
                { // 标志
                    zero = digit[0];
                }
                else if (idx == 0 && vidx > 0 && zeroSerNum < 4)
                {
                    prefix += vunit[vidx - 1];
                    zero = '0';
                }
                continue;
            }
            zeroSerNum = 0; // 连续0次数清零
            if (zero != '0')
            { // 如果标志不为0,则加上,例如万,亿什么的
                prefix += zero;
                zero = '0';
            }
            prefix += digit[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、判断这个数的长度,就是看它有几位数,比如你说的123就是三位数
2、有几位数就对10求余几次,这样做的目的是把数从个位一直往上分离出来。
比如你说的123: 123%10 = 3(个位数) 123/10 = 12 ;
12%10 = 2 (十) 12/10 = 1;
1% 10 = 1 (百) (总共求了三个余,求余完毕)
3、你可以设置1~9第个数对应的大小,因为求余出来第次都是个位数,所以应该很方便
4、接下来就是输出了,因为我们是从个位,十位,百位……这样很上走的,所以输出可能要倒着输出

我也没有做过,只是有这个想法,供你参考,你也可以查一下看JAVA里有没有可以处理这种问题的类,说不定很容易就解决了,我是不太懂JAVA的(我是个JAVA初学都),思想是从C语言的角度想的。