LeetCode第13题目罗马数字转整数

继续打卡算法题,今天学习的是LeetCode的第13题目罗马数字转整数,这道题目是道简单题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些帮助。

分析一波题目

这道题和LeetCode第12题目整数转罗马数字是思路一致的操作,12题的核心思路就是从大到小表示罗马数字,因此本题也一样的,从大到小解析罗马数字就可以解决。

我们先从大到小编排罗马数字和整数的关系

java 复制代码
        map.put("M",1000);
        map.put("CM",900);
        map.put("D",500);
        map.put("CD",400);
        map.put("C",100);
        map.put("XC",90);
        map.put("L",50);
        map.put("XL",40);
        map.put("X",10);
        map.put("IX",9);
        map.put("V",5);
        map.put("IV",4);
        map.put("I",1);

比如LVIII, L先匹配到50,V先匹配到5,I匹配到1,因此结果=50+5+1+1+1=58

编码实现

java 复制代码
class Solution {
    public int romanToInt(String s) {
        //结局此题的秘诀:先匹配大的
        //这个题目用罗马数字表示数字 ,罗马数字只有七种另加3种特殊情况,我们应优先使用大的罗马数字表示数字。先把大的用完,直到为0
        //排序的map
        Map<String, Integer> map = new LinkedHashMap<>();

        map.put("M",1000);
        map.put("CM",900);
        map.put("D",500);
        map.put("CD",400);
        map.put("C",100);
        map.put("XC",90);
        map.put("L",50);
        map.put("XL",40);
        map.put("X",10);
        map.put("IX",9);
        map.put("V",5);
        map.put("IV",4);
        map.put("I",1);
        int num = 0;
        
        while(s.length() > 0) {
            //从大的罗马数字开始
            for (Map.Entry<String, Integer> entry : map.entrySet()) {
                String key = entry.getKey();
                //大的罗马数字能够表示当前整数,取出来
                while(s.startsWith(key)) {
                    s = s.substring(key.length());
                    System.out.println(s);
                    Integer value = entry.getValue();
                    num = num + value;
                }
            }
        }
        return num;
    }   
}

总结

这道题目主要是根据罗马数字的特点,就可以明白解决本题的诀窍,所以这类题目需要注意观察考查的知识点特征,根据特征专征解决。

相关推荐
CM莫问2 小时前
<论文>(微软)避免推荐域外物品:基于LLM的受限生成式推荐
人工智能·算法·大模型·推荐算法·受限生成
康谋自动驾驶3 小时前
康谋分享 | 自动驾驶仿真进入“标准时代”:aiSim全面对接ASAM OpenX
人工智能·科技·算法·机器学习·自动驾驶·汽车
C++ 老炮儿的技术栈4 小时前
什么是函数重载?为什么 C 不支持函数重载,而 C++能支持函数重载?
c语言·开发语言·c++·qt·算法
yychen_java4 小时前
R-tree详解
java·算法·r-tree
MarkHard1235 小时前
Leetcode (力扣)做题记录 hot100(62,64,287,108)
算法·leetcode·职场和发展
一只鱼^_6 小时前
牛客练习赛138(首篇万字题解???)
数据结构·c++·算法·贪心算法·动态规划·广度优先·图搜索算法
一只码代码的章鱼6 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法
邹诗钰-电子信息工程6 小时前
嵌入式自学第二十一天(5.14)
java·开发语言·算法
↣life♚6 小时前
从SAM看交互式分割与可提示分割的区别与联系:Interactive Segmentation & Promptable Segmentation
人工智能·深度学习·算法·sam·分割·交互式分割
大学生小郑7 小时前
Go语言八股之Mysql基础详解
mysql·面试