A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 微行者 中级黑马   /  2014-7-12 21:48  /  1300 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

要求用户输入一个小于等于9999的正整数,要求输出其汉字读法。
   比如用户输入1024,则输出“一万零二十四”,如果用户输入“123”则输出“一百二十三”

3 个回复

正序浏览
查表法,估计麻烦的很啊。或者让数字对应中文,判断什么时候加“零”,然后再打印输出。这是个个人思路,见供参考
回复 使用道具 举报
这里有到类似的题,看看就知道了,是转换金额的,你把金额去掉就OK 了,。


例如:101000001010   转换为   壹仟零壹拾亿零壹仟零壹拾圆整
*/
import java.util.*;
public class Test10{
        public static void main(String[] args){
                Scanner in=new Scanner(System.in);
                int num=in.nextInt();
                System.out.println(hangeToBig(num));
        }
        public static String hangeToBig(int 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; // 返回正确表示
        }
}
回复 使用道具 举报
先占个楼,得像个好的办法做,要用基本的方法.
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马