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

总结

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

相关推荐
代码游侠2 小时前
日历的各种C语言实现方法
c语言·开发语言·学习·算法
春日见6 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊6 小时前
”回调“高级
算法·青少年编程
云里雾里!6 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
WYiQIU6 小时前
11月面了7.8家前端岗,兄弟们12月我先躺为敬...
前端·vue.js·react.js·面试·前端框架·飞书
一只侯子9 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue9 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈9 小时前
Python数据结构
数据结构·算法·排序算法
J***793910 小时前
后端在分布式系统中的数据分片
算法·哈希算法
Dream it possible!11 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试