黑马程序员技术交流社区
标题:
求更简单的写法,百度写的看不懂
[打印本页]
作者:
HeiMa-黄倲江
时间:
2012-11-7 03:51
标题:
求更简单的写法,百度写的看不懂
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; // 返回正确表示
}
作者:
杨志男
时间:
2012-11-7 14:31
这道题小弟也不甚明了,不过有个不一样的写法,如果兄台看了有所领悟,可否为小弟解惑?
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("^整$", "零元整");
}
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2