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;
    }   
}

总结

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

相关推荐
王老师青少年编程16 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove2 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
小程故事多_802 小时前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
leoufung2 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了2 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL2 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰3 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商3 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法