Java实现人民币大写精讲
想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧!
本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到分
经典测试数据:
0
希望转换出来的结果为:
零元零角零分
1234
希望转换出来的结果为:
壹仟贰佰叁拾肆元零角零分
9999
希望转换出来的结果为:
玖仟玖佰玖拾玖元零角零分
1234.5
希望转换出来的结果为:
壹仟贰佰叁拾肆元伍角零分
1234.9
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角零分
1234.56
希望转换出来的结果为:
壹仟贰佰叁拾肆元伍角陆分
1234.99
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角玖分
1234.994
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角玖分
1234.999
希望转换出来的结果为:
壹仟贰佰叁拾伍元零角零分
999999999999.999
希望转换出来的结果为:
数据过大,无法进行转换,请重新输入!
程序源码如下,含注释:
package com.tfj.algorithm; import java.util.Scanner; public class RenMingBi {
private boolean zero;
String[] strHan = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };
String[] moneyCount = { "", "拾", "佰", "仟" }; RenMingBi() {
zero = false;
} private String[] divide(double digitalRmbValue) {
// 处理整数
long intPart = (long) (digitalRmbValue);
// 处理小数,把小数转换成整数形式处理,并进行四舍五入,此时小数四舍五入之后为100的应该另外加一层处理
long decimalPart = Math
.round((double) Math.round((digitalRmbValue - intPart) * 10000) / 100);
// System.out.println("整数部分为:" + intPart + "小数部分为:" + (digitalRmbValue - intPart));
if (decimalPart == 100) {
intPart += 1;
}
// System.out.println("四舍五入之后整数部分为:" + intPart + "小数部分为:" + decimalPart); String strIntPart = "";
if (intPart == 0)
strIntPart = "0";
else {
strIntPart = "" + intPart;
} String strDecimalPart = "";
if (decimalPart < 10 && decimalPart >= 0)
strDecimalPart = "0" + decimalPart;
else {
strDecimalPart = "" + decimalPart;
}
// 处理输入为0的时候
if (intPart == 0 && decimalPart == 0) {
zero = true;
}
// System.out.println("准换为String后,整数部分为:" + strIntPart + "小数部分为:" + strDecimalPart);
return new String[] { strIntPart, strDecimalPart };
} // 用来转换小数部分
private String transDecimal(String str) {
if (str.equals("100") || str.equals("00")) {
return "零角零分";
} else {
String strResult;
char[] strRmb = new char[20];
strRmb = str.toCharArray();
if (strRmb[0] == '0' && strRmb[1] == '0') {
strResult = "";
} else {
int dm = strRmb[0] - '0';
int dn = strRmb[1] - '0';
strResult = strHan[dm] + "角" + strHan[dn] + "分";
}
return strResult;
}
} // 用来转换整数部分
private String transInt(String str) {
char[] firstFourBitRmb = new char[20];
firstFourBitRmb = str.toCharArray();
int len = firstFourBitRmb.length;
String strResult = "";
for (int i = 0; i < len; i++) {
/**
* 这里开启之后会显示成通俗易懂的格式,例如1001,会转化为:壹仟零壹元,而不是:壹仟零佰零拾壹元, 但我希望得到的是后面这种,因为发票所需显示的就是后面这种
**/ // if (firstFourBitRmb[i] == '0' && i < len) {
// boolean zeroFlag = false;
// while (i < len && firstFourBitRmb[i] == '0') {
// zeroFlag = true;
// i++;
// }
// if (i != len && zeroFlag == true)
// strResult += "零";
// i--;
// } else {
// int m = firstFourBitRmb[i] - '0';
// strResult += strHan[m] + moneyCount[len - i - 1];
// }
int m = firstFourBitRmb[i] - '0';
strResult += strHan[m] + moneyCount[len - i - 1];
}
return strResult;
} public String transComb() {
String[] strTempRmb = new String[2];
double strValue = 0D;
Scanner sc = new Scanner(System.in); System.out.println("请输入具体金额,结果会精确到分:");
strValue = sc.nextDouble();
RenMingBi nr = new RenMingBi();
strTempRmb = nr.divide(strValue);
// 转换小数部分
String result1 = nr.transDecimal(strTempRmb[1]); // 转换整数部分
String result2 = "";
int len = strTempRmb[0].length();
if (len > 12)
return "数据过大,无法进行转换,请重新输入!";
else {
if (len >= 9) {
String strBit1 = strTempRmb[0].substring(0, len - 8);
String strBit2 = strTempRmb[0].substring(len - 8, len - 4);
String strBit3 = strTempRmb[0].substring(len - 4, len);
String strResult1 = nr.transInt(strBit1) + "亿";
String strResult2 = nr.transInt(strBit2) + "万";
String strResult3 = nr.transInt(strBit3) + "元";
result2 = strResult1 + strResult2 + strResult3;
} else if (len >= 5) {
String strBit1 = strTempRmb[0].substring(0, len - 4);
String strBit2 = strTempRmb[0].substring(len - 4, len);
String strResult1 = nr.transInt(strBit1) + "万";
String strResult2 = nr.transInt(strBit2) + "元";
result2 = strResult1 + strResult2;
} else if (len >= 1) {
if (nr.zero == true) {
result2 = "零元";
} else
result2 = nr.transInt(strTempRmb[0]) + "元";
}
return result2 + result1;
}
} public static void main(String[] args) {
RenMingBi rmb = new RenMingBi();
while (true) {
System.out.println(rmb.transComb());
}
}
}
注:输出注释可自行打开,以供测试
运行结果如下:
Java实现人民币大写精讲的更多相关文章
- 深入Java核心 Java内存分配原理精讲
深入Java核心 Java内存分配原理精讲 栈.堆.常量池虽同属Java内存分配时操作的区域,但其适用范围和功用却大不相同.本文将深入Java核心,详细讲解Java内存分配方面的知识. Java内存分 ...
- Java实现人民币大写代码解析
想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧! 本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到 ...
- Java岗 面试考点精讲(基础篇01期)
即将到来金三银四人才招聘的高峰期,渴望跳槽的朋友肯定跟我一样四处找以往的面试题,但又感觉找的又不完整,在这里我将把我所见到的题目做一总结,并尽力将答案术语化.标准化.预祝大家面试顺利. 术语会让你的面 ...
- Java集合详解8:Java的集合类细节精讲
Java集合详解8:Java集合类细节精讲 今天我们来探索一下Java集合类中的一些技术细节.主要是对一些比较容易被遗漏和误解的知识点做一些讲解和补充.可能不全面,还请谅解. 本文参考:http:// ...
- Java岗 面试考点精讲(基础篇02期)
1. 两个对象的hashCode相同,则equals也一定为true,对吗? 不对,答案见下面的代码: @Override public int hashCode() { return 1; } 两个 ...
- Java岗 面试考点精讲(网络篇03期)
1. OSI七层模型 总结一下: 应用用层按协议打包数据 由传输层加上双方的端口号 由网络层加上双方的IP地址 由链路层加上双方的MAC地址,并将数据拆分成数据帧 数模信号转换并由物理层传输到另一端 ...
- 总结:Java 集合进阶精讲2-ArrayList
知识点:Java 集合框架图 总结:Java 集合进阶精讲1 总结:Java 集合进阶精讲2-ArrayList 初探: ArrayList底层结构是数组,是List接口的 可变数组的实现,所以会占用 ...
- 总结:Java 集合进阶精讲1
知识点:Java 集合框架图 总结:Java 集合进阶精讲1 总结:Java 集合进阶精讲2-ArrayList 集合进阶1---为集合指定初始容量 集合在Java编程中使用非常广泛,当容器的量变得非 ...
- java高级精讲之高并发抢红包~揭开Redis分布式集群与Lua神秘面纱
java高级精讲之高并发抢红包~揭开Redis分布式集群与Lua神秘面纱 redis数据库 Redis企业集群高级应用精品教程[图灵学院] Redis权威指南 利用redis + lua解决抢红包高并 ...
随机推荐
- ios面试题集锦(一)
一.前言部分 文中的问题多收集整理自网络,不保证100%准确,还望斟酌采纳. 1.iOS9有哪些新特性? 答案: 1)改进了 Siri 基于日期.位置和相簿名称来搜索个人照片和视频 要求 Siri 来 ...
- net下 Mysql Linq的使用, 更新数据,增加数据,删除数据
net下访问mysql主要有2种方法: 1.字符串拼接访问 a.mysql官网下载并安装mysql-connector-net. b项目中引用mysql.data等 所有增删改查可以通过拼接sql语句 ...
- 374. Guess Number Higher or Lower
We are playing the Guess Game. The game is as follows: 我们来玩一个游戏,规则如下: I pick a number from 1 to n. Y ...
- Linux作业控制
在Linux中,利用Shell的作业控制是比较常用的操作,在这一节中我们将探究作业控制相关的操作.为了方便我们查看区分不同的进行,我们编写如下程序,其功能是每间隔2秒输出一次自己的编号. /* ** ...
- DataTable 数据量大时,导致内存溢出的解决方案
/// <summary> /// 分解数据表 /// </summary> /// <param name="originalTab">需要分 ...
- 简单的JQuery分页代码
1. [代码][JavaScript]代码 001 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" ...
- ASP.Net MVC 生成安全验证码
---------html <td>验证码:</td> <td> <img src="/Logi ...
- Memcache存储大数据的问题
Memcached存储单个item最大数据是在1MB内,假设数据超过1M,存取set和get是都是返回false,并且引起性能的问题. 我们之前对排行榜的数据进行缓存,因为排行榜在我们全部sql se ...
- Android Studio API 文档_下载与使用
如何下载API 说明: 时间: 2016/7/9 根据百度经验步骤改编(百度经验), 但是比它更好, 亲测可用 1.1 下载API文档: 1.1.1 SDK Manager 1.1.2 1.1.3 ( ...
- poj 2175 Evacuation Plan 最小费用流判定,消圈算法
题目链接 题意:一个城市有n座行政楼和m座避难所,现发生核战,要求将避难所中的人员全部安置到避难所中,每个人转移的费用为两座楼之间的曼哈顿距离+1,题目给了一种方案,问是否为最优方案,即是否全部的人员 ...