当前位置: 代码迷 >> J2SE >> 一个面试题,该如何做
  详细解决方案

一个面试题,该如何做

热度:16   发布时间:2016-04-24 12:23:43.0
一个面试题,该怎么做
把数字转换成大写中文,题目上说明在某些财务软件会用到,因此还需要判断位数。

例如“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语言的角度想的。
  相关解决方案