中文数字转换成阿拉伯数字(一千二百三十四万五千六百七十八-->12345678)

昨天老大问我又没有写过中文数字转换成阿拉伯数字,我说没有,我说那应该简单啊,就是将中文对应的数字换成阿拉伯数字就好了啊,比如一就换成1,二就换成2…十换成10。可是那么问题来了…
一十二呢…不能是1102吧…这不就坑爹了吗?一百万呢…所有我苦苦思索,花费了我差不多半天的时间,终于写出了下面的程序。

public static void main(String[] args){
		
		Map<Character, String> numberMap = new HashMap<Character, String>();
		numberMap.put('零', "0");
		numberMap.put('一', "1");
		numberMap.put('二', "2");
		numberMap.put('三', "3");
		numberMap.put('四', "4");
		numberMap.put('五', "5");
		numberMap.put('六', "6");
		numberMap.put('七', "7");
		numberMap.put('八', "8");
		numberMap.put('九', "9");
		Map<Character, String> numberBit = new HashMap<Character, String>();
		numberBit.put('十', "10");
		numberBit.put('百', "100");
		numberBit.put('千', "1000");
		numberBit.put('万', "10000");
		/**
		 * 思路:循环遍历数字字符数组
		 *       举例:
		 *       九                                    把numberMap的key为九取出, 即9
		 *       九十                               把numberMap的key为九取出并乘以numberBit的key为十的值,即9*10=90
		 *       九十一                          把numberMap的key为九取出并乘以numberBit的key为十的值,然后加上numberMap的key为一 的值,即9*10+1=91
		 *       十一                               同上10+1=11
		 *       一百万                          先取出numberMap为一的key的值,然后乘以numberBit的key为百的值,然后乘以numberBit的key为万的值,即1*100*10000=1000000
		 *       一百八十八万           1*100+(8*10+8)*10000=100+88*10000=1880000 
		 *                       
		 */
		long number = 0;//1008571
		String chinaNumberStr = "一千二百三十四万五千六百七十八";//12   叁佰贰十 320 三佰二十
		char[] arrNumber = chinaNumberStr.toCharArray();
		for (int i = 0; i < arrNumber.length; i++) {
			char num = arrNumber[i];
			if (i + 1 < arrNumber.length && numberBit.containsKey(arrNumber[i + 1])) {// 判断后面的汉字是否是位数(十百千万)
				if (numberMap.containsKey(num)) {// 如果当前的汉字不是位数
													
					if(i + 3 < arrNumber.length&&arrNumber[i + 1]=='十'&&numberMap.containsKey(arrNumber[i + 2])){
						number = number + Integer.parseInt(numberMap.get(num))* Integer.parseInt(numberBit.get(arrNumber[i + 1]));
						number = number + Integer.parseInt(numberMap.get(arrNumber[i + 2]));
						number = number * Integer.parseInt(numberBit.get(arrNumber[i + 3]));
						i=i+2;
					}else{// 取出当前对应的数字*位数对应倍数累加在number上
						number = number + Integer.parseInt(numberMap.get(num))* Integer.parseInt(numberBit.get(arrNumber[i + 1]));
					}
				} else if (numberBit.containsKey(num)) {// 如果当前的汉字是位数,即当前的汉字和后一个汉字都是位数(比如百万)
					                                      //则用number直接*后一个位数
					number = number * Integer.parseInt(numberBit.get(arrNumber[i + 1]));
				}
			} else if (numberMap.containsKey(num)) {
				number = number + Integer.parseInt(numberMap.get(num));
			} else if (num == '十' && i == 0) {//“十”特殊处理 当出现十八之类的 十在前面的情况
				number = Integer.parseInt(numberBit.get('十'));
			}
		}
		System.out.println(number);
	}

其实这个老大只是问我有没有写过类似的程序,并没有让我写它,但是我就是喜欢挑战。唉,主要是想看看我自己有没有这个能力写出这个程序来,我也是给朋友测了测,发现了一些BUG,改了不少,后面还是写出来了。不过还是有点不尽人意的地方,比如:”一千一”转换之后变成1001,这里应该是1100的,所有要想是1100必须是”一千一百”后面得加个百字。这就是这里的不足了。

我刚刚加了一个numberBit.put(‘亿’, “100000000”); 想转下一亿试一试,结果不行,可能我还要继续改进下。这里暂时只能转换千万及千万以下的数字,不过对于一般的转换也足够了,如果转”壹仟壹佰”这种数字的直接改上面的map里面的key就行了。

我的这个算法有点过于复杂,每个程序的思路第一次都会比较复杂,后面多想几次会想出更加简便的算法,所以你们想出了更好的算法欢迎评论。我去改进我的代码了,之后我会把我改进的代码贴上来的。

    原文作者:lucky_白杨
    原文地址: https://blog.csdn.net/u013632755/article/details/44962171
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞