数字转换为英文

输入为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型非负数转换为英文的更多相关文章

  1. Linux C 知识 char型数字转换为int型 int型 转换为Char

    前言 在九度oj做acm的时候,经常会遇到了char类型和int类型相互转化的问题,这里进行一下总结.今后,可能会多次更新博客,因为半年做了很多总结,但是都是保存在word文档上了,现在开始慢慢向CS ...

  2. C# ASP.NET 转换为int型的方法 很实用

    很多新手在搞c#或者.net开发的时候总会碰到一些小问题,如何知道字符能不能为int型  在这里我写了一个小的函数仅供大家参考: /// <summary> /// 判断是不是int型 / ...

  3. sqlserver中将varchar类型转换为int型再进行排序的方法

    sql中把varchar类型转换为int型然后进行排序,如果我们数据库的ID设置为varchar型的 在查询的时候order by id的话 如果我们数据库的ID设置为varchar型的 在查询的时候 ...

  4. string型的“600.000”如何转换为int型

    string型的“600.000”怎么转换为int型?为什么我用int.parse不能转换? ------解决方案--------------------int.Parse("600.000 ...

  5. C字符串和C++中string的区别 &&&&C++中int型与string型互相转换

    在C++中则把字符串封装成了一种数据类型string,可以直接声明变量并进行赋值等字符串操作.以下是C字符串和C++中string的区别:   C字符串 string对象(C++) 所需的头文件名称 ...

  6. 假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么?

    假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么? 在执行这条语句的过程中,保存在result中的值被读 ...

  7. Java中String转int型的方法以及错误处理

    应要求,本周制作了一个判断一个年份是否是闰年的程序.逻辑很简单,这里就不贴代码了.可是,在这次程序编写中发现了一个问题. 在输入年份时,如果输入1)字母2)空3)超过Int上限时,就会抛excepti ...

  8. int型、long型和long long型

    long long本质上还是整型,只不过是一种超长的整型.int型:32位整型,取值范围为-2^31 ~ (2^31 - 1) . long:在32位系统是32位整型,取值范围为-2^31 ~ (2^ ...

  9. int型的数到底最大值是多少?

    本文摘自:http://blog.csdn.net/friendbaby/article/details/6822690 刚才在百度知道上看见一个网友问int型的数最大能存多少.这个问题其实计算机系统 ...

随机推荐

  1. 我做的第一个程序(菜鸟的java课堂笔记)

    内存: 堆区,栈区,常量区,计数区,代码区: 数据类型: 基本数据类型:整形,浮点型,布尔型 boolean 只能返回真假值,字符型: 引用数据类型:类,数组: 基本数据类型-->直接存放到栈区 ...

  2. 关于iphone点击readonly的input虚拟键盘不消失的情况

    今天遇到了一个比较棘手的问题,事情是这样的: 咱有一个添加地址的页面,大概长这样: 收货地址后那个"请选择收货地址"是一个readonly的input, 咱一进页面,直接点击这个& ...

  3. solr5Ik分词2

    <!--IK分词器--><fieldType name="text_ik" class="solr.TextField"><ana ...

  4. Python os模块--路径、文件、系统命令等操作

    os模块包含普遍的操作系统功能. 注意:函数参数path是文件或目录的路径,filename是文件的路径,dirname是目录的路径,路径可以是相对路径,也可绝对路径 常见或重要的函数为加粗字体 os ...

  5. js中的数组对象排序(方法sort()详细介绍)

    定义和用法 sort() 方法用于对数组的元素进行排序. 语法    arrayObject.sort(sortby) 参数sortby:可选.规定排序顺序.必须是函数. 返回值 对数组的引用.请注意 ...

  6. 使用websocket-sharp来创建c#版本的websocket服务

    当前有一个需求,需要网页端调用扫描仪,javascript不具备调用能力,因此需要在机器上提供一个ws服务给前端网页调用扫描仪.而扫描仪有一个c#版本的API,因此需要寻找一个c#的websocket ...

  7. 执行3小时超长SQL的分析优化过程:从索引遇见IS NULL,到最佳实践

    月底高峰期,对一个典型项目抽查分析时,发现了一个超级慢.全表扫描的SQL,语句很简单,AWR中赫然在列,在我统计的截止时间内还没有结束... 使用v$active_session_history进一步 ...

  8. 【Android Developers Training】 32. 向其它应用发送简单数据

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  9. 基于AFN封装的带缓存的网络请求

    给大家分享一个基于AFN封装的网络请求 git: https://github.com/zhouxihi/NVNetworking #带缓存机制的网络请求 各类请求有分带缓存 , 不带缓存, 可自定义 ...

  10. 使用ReflectionToStringBuilder实现toString方法

    使用ReflectionToStringBuilder实现toString方法 org.apache.commons.lang.builder.ReflectionToStringBuilder是co ...