zoukankan      html  css  js  c++  java
  • 设计函数实现将中文数字转换成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;
           }
    }
    路慢慢其休远羲,吾将上下而求所
  • 相关阅读:
    Centos7:mariadb替换mysql
    CentOS5 部署 戴尔OMSA
    《Zero MQ》
    可扩展的Web架构和分布式系统
    队列实现
    超级好用的正则表达式网站
    <转>undefined与null的区别
    JS事件
    sublime text 3 快捷键
    设置className的方式(不使用setAttribute)
  • 原文地址:https://www.cnblogs.com/garinzhang/p/2568874.html
Copyright © 2011-2022 走看看