把int型非负数转换为英文
数字转换为英文
输入为int型非负数,最大值为2^31 - 1 = 2 147 483 647
输出为String英文,最大输出为Two Billion One Hundred Forty Seven Million Four Hundred Eighty Three Thousand Six Hundred Forty Seven
输出要求每个单词首字母大写,之间用空格隔开,不需要用“and”做连词
例如:
123 -> "One Hundred Twenty Three" 12345 -> "Twelve Thousand Three Hundred Forty Five" 1234567 -> "One Million Two Hundred Thirty Four Thousand Five Hundred Sixty Seven"
处理思路
观察数字2 147 483 647,可以看出由4段组成;每段都是0到999的数字
尝试将数字分段处理;截取每段数字,写专门的函数处理0~999的数字;最后将它们连接起来
编制String数组存放需要的数字;需要时从数组中取用
完整Java代码如下:
/**
*
* @author Rust Fisher
* biggest number = 2 147 483 648 - 1
* Two Billion One Hundred Forty Seven Million Four Hundred Eighty Three Thousand Six Hundred Forty Seven
*/
public class Int2Eng {
public static String numberToWords(int num) {
String result = "";
int inputNum = num;
if (num == 0) {
result = "Zero";
return result;
}
if (inputNum/1000 == 0 ) {//0 < num < 1000
return getThousand(inputNum%1000);// 处理 xxx
}
result = getThousand(inputNum%1000);
inputNum = inputNum/1000; //Rust:cut the tail 2 147 483 xxx
if (inputNum/1000 == 0) { // 1000 <= num < 1 000 000
if (result.equals("")) {
return (getThousand(inputNum%1000) + " Thousand");
} else {
return (getThousand(inputNum%1000) + " Thousand " + result);
}
} else {// 1 000 000 < num
if (result.equals("") && inputNum%1000 == 0) {
result = getThousand(inputNum%1000);//do nothing
} else if (!result.equals("") && inputNum%1000 != 0){
result = getThousand(inputNum%1000) + " Thousand " + result;
} else if (result.equals("") && inputNum%1000 != 0) {
result = getThousand(inputNum%1000) + " Thousand" + result;
}
}
inputNum = inputNum/1000;
if (inputNum/1000 == 0) {//1 000 000 <= num < 1 000 000 000
if (result.equals("")) {
return (getThousand(inputNum%1000) + " Million");
} else {
return (getThousand(inputNum%1000) + " Million " + result);
}
} else {
if (result.equals("") && inputNum%1000 == 0) {
result = getThousand(inputNum%1000);
} else if (!result.equals("") && inputNum%1000 != 0){
result = getThousand(inputNum%1000) + " Million " + result;
} else if (result.equals("") && inputNum%1000 != 0) {
result = getThousand(inputNum%1000) + " Million" + result;
}
}
inputNum = inputNum/1000;
if (result.equals("")) {
if (inputNum == 1) {
return ("One"+ " Billion");
} else if (inputNum == 2) {
return ("Two"+ " Billion");
}
} else {
if (inputNum == 1) {
return ("One"+ " Billion " + result);
} else if (inputNum == 2) {
return ("Two"+ " Billion " + result);
}
}
return result;
}
public static String getThousand(int input) {
String MaxNum = "Two Billion One Hundred Forty Seven Million" +
" Four Hundred Eighty Three Thousand Six Hundred Forty Eight";
String single[] = {"Zero", "One", "Two", "Three", "Four", "Five", "Six",
"Seven", "Eight", "Nine", "Ten", "Eleven", "Twelve", "Thirteen",
"Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", "Nineteen"};
String tens[] = {"Twenty","Thirty","Forty","Fifty","Sixty","Seventy","Eighty","Ninety"};
String output = "";
int res1 = input%1000;
if (res1/100 != 0) {
output = output + single[res1/100] + " Hundred";
}
res1 = res1%100;// 1~99
if (res1 == 0) {
// do nothing
} else if (res1 < 20) {
if (output.equals("")) {
output = output + single[res1];
} else {
output = output + " " + single[res1];
}
return output;
} else if (res1 >= 20) {
if (output.equals("")) {
output = tens[res1/10 - 2];
} else {
output = output + " " + tens[res1/10 - 2];
}
}
res1 = res1%10;
if (res1 == 0) {
} else {
output = output + " " +single[res1];
}
return output;
}
public static void main(String args[]) {
System.out.println(numberToWords(2127483622));
System.out.println(numberToWords(12));
System.out.println(numberToWords(3555000));
System.out.println(numberToWords(1000));
System.out.println(numberToWords(1000000));
System.out.println(numberToWords(2000000010));
}
}
输出:
Two Billion One Hundred Twenty Seven Million Four Hundred Eighty Three Thousand Six Hundred Twenty Two
Twelve
Three Million Five Hundred Fifty Five Thousand
One Thousand
One Million
Two Billion Ten
整个程序是顺序执行的,条件合适时即返回结果
把int型非负数转换为英文的更多相关文章
- Linux C 知识 char型数字转换为int型 int型 转换为Char
前言 在九度oj做acm的时候,经常会遇到了char类型和int类型相互转化的问题,这里进行一下总结.今后,可能会多次更新博客,因为半年做了很多总结,但是都是保存在word文档上了,现在开始慢慢向CS ...
- C# ASP.NET 转换为int型的方法 很实用
很多新手在搞c#或者.net开发的时候总会碰到一些小问题,如何知道字符能不能为int型 在这里我写了一个小的函数仅供大家参考: /// <summary> /// 判断是不是int型 / ...
- sqlserver中将varchar类型转换为int型再进行排序的方法
sql中把varchar类型转换为int型然后进行排序,如果我们数据库的ID设置为varchar型的 在查询的时候order by id的话 如果我们数据库的ID设置为varchar型的 在查询的时候 ...
- string型的“600.000”如何转换为int型
string型的“600.000”怎么转换为int型?为什么我用int.parse不能转换? ------解决方案--------------------int.Parse("600.000 ...
- C字符串和C++中string的区别 &&&&C++中int型与string型互相转换
在C++中则把字符串封装成了一种数据类型string,可以直接声明变量并进行赋值等字符串操作.以下是C字符串和C++中string的区别: C字符串 string对象(C++) 所需的头文件名称 ...
- 假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么?
假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么? 在执行这条语句的过程中,保存在result中的值被读 ...
- Java中String转int型的方法以及错误处理
应要求,本周制作了一个判断一个年份是否是闰年的程序.逻辑很简单,这里就不贴代码了.可是,在这次程序编写中发现了一个问题. 在输入年份时,如果输入1)字母2)空3)超过Int上限时,就会抛excepti ...
- int型、long型和long long型
long long本质上还是整型,只不过是一种超长的整型.int型:32位整型,取值范围为-2^31 ~ (2^31 - 1) . long:在32位系统是32位整型,取值范围为-2^31 ~ (2^ ...
- int型的数到底最大值是多少?
本文摘自:http://blog.csdn.net/friendbaby/article/details/6822690 刚才在百度知道上看见一个网友问int型的数最大能存多少.这个问题其实计算机系统 ...
随机推荐
- 打印杨辉三角--for循环
要求打印7行直角杨辉三角 杨辉三角特点: 第1行和第2行数字都为1: 从第三行开始,除去开头和结尾数字为1,中间数字为上一行斜对角两个数字的和. 如下图: 打印结果: 代码如下: package 杨辉 ...
- java中File类中list()和listFiles()方法区别
list()和listFiles()方法区别: 1.返回值类型不同:前者为String数组,后者为File对象数组 2.数组中元素内容不同:前者为string类型的[文件名](包含后缀名),后者为Fi ...
- 2015阿里巴巴安全峰会PPT
有幸参加了阿里巴巴安全峰会,不得不佩服阿里巴巴神盾局,真牛B!然后亲眼目睹了第二天的各大厂商牛(zhuang)B人才上台演讲,有被捧的,有被喷的,呵呵.总的来说,大家的分享精神还是阔以的. 下面是会议 ...
- [1] 插件架构(PLUG-IN)
网上的一种比较好对插件的定义是:插件(Plug-in,又称addin.add-in.addon或add-on,又译外挂)也称为扩展,是一种遵循一定规范的应用程序接口编写出来的程序,主要是用来扩展软件功 ...
- 多个项目MyEclipse中启动出现OutOfMemoryError: PermGen space如何解决
在MyEclipse中启动程序运行,报错java.lang.OutOfMemoryError: PermGen space应该怎么办?这是eclipse 内存不够的原因. PermGen space的 ...
- node.js如何制作命令行工具(一)
之前使用过一些全局安装的NPM包,安装完之后,可以通过其提供的命令,完成一些任务.比如Fis3,可以通过fis3 server start 开启fis的静态文件服务,通过fis3 release开启文 ...
- PHPCMS v9 自定义表单添加验证码
1. 在 \phpcms\templates\default\formguide\show.html 中添加验证码显示 <input type="text" id=&quo ...
- XCOM2中敌对生物设计分析(Aliens篇)
Aliens Aliens作为游戏设定中入侵的外星人,有各式外貌及奇特的战斗方式,掌握一些高能科技或利用精神力量进行攻击 Sectoid 使用灵能战斗的外星人,并无高级版本,初级便会使用精神控制,生命 ...
- 你不知道的 flex 技巧
一.使用 Auto Margins 对齐 不需要给图片使用任何的 flex,也不需要给父容器设置 space-between,只需要给 ' BUY-BUY-BUY' 按钮设置 margin-left: ...
- 如何远程调试zookeeper集群
我们在阅读一些源码的时候,如果能调试源代码将会大大的提高我们的阅读效率.最近在学习zookeeper源码,分享下如何调试zookeeper集群. zookeeper代码,调试环境搭建 1.下载zook ...