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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 李厚斌 中级黑马   /  2014-3-31 01:36  /  1693 人查看  /  2 人回复  /   1 人收藏 转载请遵从CC协议 禁止商业使用本文

金额转换,阿拉伯数字转换成中国传统形式。

例如:101000001010   转换为   壹仟零壹拾亿零壹仟零壹拾圆整

评分

参与人数 1黑马币 +1 收起 理由
枫儿 + 1 神马都是浮云

查看全部评分

2 个回复

倒序浏览
希望能帮到你:
  1. import java.io.*;
  2. public class Test {

  3.         public static void main(String[] args) {
  4.                 String strNum="";
  5.                 double dNum;
  6.                 System.out.println("输入:");
  7.                 BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
  8.                 try{
  9.                 strNum=br.readLine();
  10.                 }catch(IOException e){}
  11.                 dNum=Double.parseDouble(strNum);
  12.                 System.out.println("四舍五入,精确到(分),转化成大写:");
  13.                 System.out.println(changeToBig(dNum));
  14.                 System.gc();
  15.         }

  16.         public static String changeToBig(double value) {
  17.                 char[] hunit = { '拾', '佰', '仟' }; // 段内位置表示
  18.                 char[] vunit = { '万', '亿' }; // 段名表示
  19.                 char[] digit = { '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示
  20.                 long midVal = (long) (value * 100+0.5); // 转化成整形,四舍五入
  21.                 String valStr = String.valueOf(midVal); // 转化成字符串
  22.                 String head = valStr.substring(0, valStr.length() - 2); // 取整数部分
  23.                 String rail = valStr.substring(valStr.length() - 2); // 取小数部分

  24.                 String prefix = ""; // 整数部分转化的结果
  25.                 String suffix = ""; // 小数部分转化的结果
  26.                 // 处理小数点后面的数
  27.                 if (rail.equals("00")) { // 如果小数部分为0
  28.                         suffix = "整";
  29.                 } else {
  30.                         suffix = digit[rail.charAt(0) - '0'] + "角"
  31.                                         + digit[rail.charAt(1) - '0'] + "分"; // 否则把角分转化出来
  32.                 }
  33.                 // 处理小数点前面的数
  34.                 char[] chDig = head.toCharArray(); // 把整数部分转化成字符数组
  35.                 boolean preZero = false; // 标志当前位的上一位是否为有效0位(如万位的0对千位无效)
  36.                 byte zeroSerNum = 0; // 连续出现0的次数
  37.                 for (int i = 0; i < chDig.length; i++) { // 循环处理每个数字
  38.                         int idx = (chDig.length - i - 1) % 4; // 取段内位置
  39.                         int vidx = (chDig.length - i - 1) / 4; // 取段位置

  40.                         if (chDig[i] == '0') { // 如果当前字符是0
  41.                                 preZero = true;
  42.                                 zeroSerNum++; // 连续0次数递增
  43.                                 if (idx == 0 && vidx > 0 && zeroSerNum < 4) {
  44.                                         prefix += vunit[vidx - 1];
  45.                                         preZero = false; // 不管上一位是否为0,置为无效0位
  46.                                 }
  47.                         }
  48.                         else {
  49.                                 zeroSerNum = 0; // 连续0次数清零
  50.                                 if (preZero) { // 上一位为有效0位
  51.                                         prefix += digit[0]; // 只有在这地方用到'零'
  52.                                         preZero = false;
  53.                                 }
  54.                                 prefix += digit[chDig[i] - '0']; // 转化该数字表示
  55.                                 if (idx > 0)
  56.                                         prefix += hunit[idx - 1];
  57.                                 if (idx == 0 && vidx > 0) {
  58.                                                 prefix+=vunit[(vidx+1)%2];
  59.                                                 for(int j=0;j<(vidx+1)/2-1;j++){
  60.                                                         prefix+=vunit[1];
  61.                                                 }
  62.                                 }
  63.                         }
  64.                 }
  65.                 if (prefix.length() > 0)
  66.                         prefix += '圆'; // 如果整数部分存在,则有圆的字样
  67.                 return prefix + suffix; // 返回正确表示
  68.         }
  69. }
复制代码



评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

回复 使用道具 举报 1 0
public class Change {

public static String[] cn={"仟","佰","拾","亿","仟","佰","拾","万","仟","佰","拾","圆整"};
public static String[] number={"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"};
public static String getString(long n)
{
String money=""+n;
if(money.length()>cn.length)
return "钱太多";
String str="";
for(int i=0;i<money.length();i++)
str+=number[Integer.parseInt(""+money.charAt(i))]+cn[cn.length-money.length()+i];
return str;
}
public static void main(String[] args) {
System.out.print(getString(345123456));
}
}

个人意见,只能帮你到这了

评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

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