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

总结

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

相关推荐
2301_8227032017 分钟前
鸿蒙flutter三方库实战——教育与学习平台:Flutter Markdown
学习·算法·flutter·华为·harmonyos·鸿蒙
Jia ming27 分钟前
C语言实现日期天数计算
c语言·开发语言·算法
无限进步_1 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
苏纪云1 小时前
蓝桥杯考前突击
c++·算法·蓝桥杯
W23035765731 小时前
经典算法详解:最长公共子序列 (LCS) —— 从暴力递归到动态规划完整实现
算法·动态规划·最长子序列
pzx_0011 小时前
【优化器】 随机梯度下降 SGD 详解
人工智能·python·算法
小肝一下2 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
无限进步_2 小时前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
Meme Buoy2 小时前
18.补充数学1:生成树-最短路径-最大流量-线性规划
数据结构·算法
paeamecium2 小时前
【PAT甲级真题】- Count PAT‘s (25)
c++·算法·动态规划·pat考试·pat