设计函数实现将中文数字转换成int型数字,例如”一百二十三” 转换成123

算法题:设计函数实现将中文数字转换成int型数字,例如”一百二十三” 转换成123,要求写出测试用例。

 

package com.test;
 
import java.util.*;
 
public class CNCharsToNumber {
       public static void main(String[] args) {
              System.out.println("Test: " + CNCharsToNumber.CnToNumber("一十亿零五百万八千零二十三"));
       }
       public static int CnToNumber(String str) {
              int result = 0;
              HashMap<Character, Integer> nM = new HashMap<Character, Integer>();
              nM.put('一', 1);
              nM.put('二', 2);
              nM.put('三', 3);
              nM.put('四', 4);
              nM.put('五', 5);
              nM.put('六', 6);
              nM.put('七', 7);
              nM.put('八', 8);
              nM.put('九', 9);
              HashMap<Character, Integer> bitMap = new HashMap<Character, Integer>();
              bitMap.put('十', 10);
              bitMap.put('百', 100);
              bitMap.put('千', 1000);
              bitMap.put('万', 10000);
              bitMap.put('亿', 100000000);
              System.out.println("Start");
              char[] charNum = str.toCharArray();
              int n, bit1 = 0, bit2 = 0;
              for(int i = 0; i < charNum.length; i++) {
                     if(nM.containsKey(charNum[i])) {
                           n = (int)nM.get(charNum[i]);
                           if(i + 1 < charNum.length && bitMap.containsKey(charNum[i + 1])){
                                  i++;
                                  bit1 = (int)bitMap.get(charNum[i]);
                                  if(i + 1 < charNum.length && bitMap.containsKey(charNum[i + 1])) {
                                         // 进位处理,例如一百万
                                         i++;
                                         bit2 = (int)bitMap.get(charNum[i]);
                                         if(result ==0) {
                                                result = n * bit1 * bit2;
                                         } else {
                                                result = result + n * bit1 * bit2;
                                         }
                                  } else { // 进位处理,例如一百
                                         if(result == 0) {
                                                result = n * bit1;
                                         } else {
                                                result = result + n * bit1;
                                         }
                                  }
                           } else { // 个位数的处理
                                  result = result + n;
                           }
                     } else if(charNum[i] == '零'){
                     } else {
                           System.out.println("The input string contain illegal characters: " + charNum[i]);
                           break;
                     }
              }
              
              return result;
       }
}

转载于:https://www.cnblogs.com/garinzhang/archive/2012/06/28/2568874.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值