汉字转数字_数字代码表示汉字

汉字转数字_数字代码表示汉字importjava.util.Scanner;importjava.util.List;importjava.util.ArrayList;importjava.util.Map;impor

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

import java.util.Scanner;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;

/*
    汉字转数字的程序。输入:八亿零二十万零一百零一   输出:800200101
    
    汉字有效字符为:零一二(两)三四五六七八九十百千万亿
*/
public class HanToNumber{
    public static void main(String args[]){
        Scanner sc = new Scanner(System.in);
        HanToNumber mainObj = new HanToNumber();
        int res = mainObj.getNumFromHan(sc.next());
        System.out.println(res);
    }

    public int getNumFromHan(String str){
        Map<Character,Integer> map = new HashMap<Character,Integer>();
        map.put('零',0);
        map.put('一',1);
        map.put('二',2);
        map.put('两',2);
        map.put('三',3);
        map.put('四',4);
        map.put('五',5);
        map.put('六',6);
        map.put('七',7);
        map.put('八',8);
        map.put('九',9);
        map.put('十',10);
        map.put('百',100);
        map.put('千',1000);
        map.put('万',10000);
        map.put('亿',100000000);
        char[] arr = str.toCharArray();
        int len = str.length();
        List<Integer> resList = new ArrayList<Integer>();
        int tmp = 0;
        
        for(int i=0; i<len; i++){
            if(!isUnit(arr[i])){
                tmp +=  Integer.parseInt(String.valueOf(map.get(arr[i])));
                if(i==len-1){
                    resList.add(tmp);
                }
            }else{
                tmp *= map.get(arr[i]);
                if(i<len-1 && !isUnit(arr[i+1]) || i==len-1){
                    resList.add(tmp);
                    tmp = 0;
                }
            }
        }

        int res = 0;
        for(Integer in:resList){
            res += in;
        }
        return res;
    }

    public boolean isUnit(char c){
        boolean isUnit = false;
        if(c=='十' || c=='百' || c=='千' || c=='万' || c=='亿'){
            isUnit = true;
        }
        return isUnit;
    }
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167955.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 重庆师范大学c语言考试系统题库,2018年重庆师范大学计算机与信息科学学院820计算机基础综合[专业硕士]之C程序设计考研核心题库…

    重庆师范大学c语言考试系统题库,2018年重庆师范大学计算机与信息科学学院820计算机基础综合[专业硕士]之C程序设计考研核心题库…一、选择题1.有以下程序:执行时若输入:Figflowerisred.则输出结果是()。A.Figflowerisred.B.Figflowefisred.C.Figflowerisred.D.Figflowerisred.【答案】A【解析】scanf()函数从输入设备按照指定的类型输入对应类型的若干个数据,遇到空格、制表符和回车时读取结束。可…

    2022年10月21日
    0
  • sharePreference的几个重点

    sharePreference的几个重点

    2022年3月3日
    92
  • vue分页列表[通俗易懂]

    vue分页列表[通俗易懂]html部分css部分js部分

    2022年10月1日
    0
  • 散列函数

    散列函数    在线性表和树表中的查询中,记录在表的位置跟记录的关键字之间不存在确定关系,也就是说在线性表和树表中查询通常要依托关键字比较,查找的效率取决于比较次数。    散列函数:一个把查找表中的关键字映射成该关键字对应的地址函数,记为Hash(key)=Addr。这里的地址可以是数组下标,索引,或内存地址等。散列函数可能将两个或两个以上的不同关键字映射到同一个地址,称这种情况为“冲突”。(假若这个函…

    2022年5月14日
    64
  • Linux下的C编程实战

    Linux下的C编程实战(一)――开发平台搭建1.引言Linux操作系统在服务器领域的应用和普及已经有较长的历史,这源于它的开源特点以及其超越Windows的安全性和稳定性。而近年来,Linu

    2021年12月25日
    37
  • h2数据库教程_NoSQL数据库入门

    h2数据库教程_NoSQL数据库入门范培忠2017-06-19  H2是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。  H2最大的用途在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。  它的另一个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。  H2的第三个用处是作为缓存,作为NoSQL的一个补充。当某

    2022年10月12日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号