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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© HeiMa-黄倲江 中级黑马   /  2012-11-7 03:51  /  1480 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

        public static String changeToBig() {
                char[] hunit = { '拾', '佰', '仟' }; // 段内位置表示
                char[] vunit = { '万', '亿' }; // 段名表示
                char[] digit = { '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示
                Scanner input = new Scanner(System.in);
                System.out.println("输入转换的整数");
                String midVal = input.next();
                String valStr = String.valueOf(midVal); // 转化成字符串

                String prefix = ""; // 整数部分转化的结果

                char[] chDig = valStr.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; // 取段内位置
                        int 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']; // 转化该数字表示
                                if (idx > 0)
                                        prefix += hunit[idx - 1];
                                if (idx == 0 && vidx > 0) {
                                        prefix += vunit[vidx - 1]; // 段结束位置应该加上段名如万,亿
                                }
                        }
                }

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

评分

参与人数 1技术分 +1 收起 理由
滔哥 + 1

查看全部评分

1 个回复

倒序浏览
这道题小弟也不甚明了,不过有个不一样的写法,如果兄台看了有所领悟,可否为小弟解惑?
package com.itheima;
import java.util.*;
public class Test10 {
/**
  *@author
  *这题用到了很多处正则表达式
  */
public static void main(String agrs[]) {
  Scanner sc = new Scanner(System.in);
  System.out.println("请输入金额:");
  System.out.println(digitUppercase(sc.nextDouble()));
}
public static String digitUppercase(double n) {
  // 将各位替换的汉字都存入数组中
  String fraction[] = { "角", "分", "毫", "厘" };
  String digit[] = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };
  String unit[][] = { { "元", "万", "亿" }, { "", "拾", "佰", "仟" } };//此二维数组的第一个一维数组中的元素代表在第二个一维数组中的元素后插入的汉字
  String head = n < 0 ? "负" : "";// 判断数值的正负,决定在开头加什么
  n = Math.abs(n);//不管正负,只拿正值进行运算
  String s = "";
  // 转化小数点后数值
  for (int i = 0; i < fraction.length; i++) {
   s += (digit[(int) (Math.floor(n * 10 * Math.pow(10, i)) % 10)] + fraction)
     .replaceAll("(零.)+", "");
  }
  // 如果没有小数点后,则以“整”结束
  if (s.length() < 1) {
   s = "整";
  }
  int integerPart = (int) Math.floor(n);//获取数值的整数部分
  // 对十位往前的数值进行替换
  for (int i = 0; i < unit[0].length && integerPart > 0; i++) {
   String p = "";
   for (int j = 0; j < unit[1].length && n > 0; j++) {
    p = digit[integerPart % 10] + unit[1][j] + p;
    integerPart = integerPart / 10;
   }
   s = p.replaceAll("(零.)*零$", "").replaceAll("^$", "零") + unit[0]
     + s;
  }
  return head
    + s.replaceAll("(零.)*零元", "元").replaceFirst("(零.)+", "")
      .replaceAll("(零.)+", "零").replaceAll("^整$", "零元整");
}
}

评分

参与人数 1技术分 +1 收起 理由
滔哥 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马