LeetCode:罗马数字转整数【13】

LeetCode:罗马数字转整数【13】

题目描述

罗马数字包含以下七种字符: I, V, X, LCD 和 M

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

  • I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
  • X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
  • C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。

示例 1:

输入: "III"
输出: 3

示例 2:

输入: "IV"
输出: 4

示例 3:

输入: "IX"
输出: 9

示例 4:

输入: "LVIII"
输出: 58
解释: L = 50, V= 5, III = 3.

示例 5:

输入: "MCMXCIV"
输出: 1994
解释: M = 1000, CM = 900, XC = 90, IV = 4.

题目分析

  刷题贵在坚持,希望自己可以保持刷题,不要成为常立志之人,hiahia。

  通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,比如IV是4,而不用IIII。如果不存在特例的话,我们就从左往右依次加起来即可,我们处理的就是这种特例的情况。

  

  我们每次与前一个元素比,如果某元素大于前一个元素,那一定时出现了4,9,40..这种数字,要想得到这个数值首先是右边减去左边,比如CM(900=1000-100),但是图中减去的却是2倍的C,为什么呢?每次与前一个元素比,那么当我们到达CM的C时,由于C左边是M,那么肯定就要累加C,后面M的左边时C,此时要进行减法,累加(C-M),这是会多计算一个C,所以要去掉多加的一个C。

Java题解

class Solution {
    public int romanToInt(String s) {
        if(s==null||s.length()==0)
            return 0;
        int res = toNumber(s.charAt(0));
        for(int j=1;j<s.length();j++)
        {
            if(toNumber(s.charAt(j))>toNumber(s.charAt(j-1)))
                res=res+(toNumber(s.charAt(j))-2*toNumber(s.charAt(j-1)));
            else
                res=res+(toNumber(s.charAt(j)));
        }
        return res;
    }

    public int toNumber(char c)
    {
        int res = 0;
        switch(c)
        {
            case ‘I‘:return 1;
            case ‘V‘:return 5;
            case ‘X‘:return 10;
            case ‘L‘:return 50;
            case ‘C‘:return 100;
            case ‘D‘:return 500;
            case ‘M‘:return 1000;
        }
        return res;
    }
}

  

原文地址:https://www.cnblogs.com/MrSaver/p/9795439.html

时间: 2024-08-03 19:55:47

LeetCode:罗马数字转整数【13】的相关文章

Leetcode#13. Roman to Integer(罗马数字转整数)

题目描述 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为两个并列的 1.12 写做 XII ,即为 X + II . 27 写做 XXVII, 即为 XX + V + II . 通常情况下,罗马数字中小的数字在大的数字的右边.但也存在特例,例如 4 不写做 IIII,而是 IV.数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数

罗马数字与整数相互转化

leetcode中的题目 直接上代码: 1 def int2roman(num): 2 ret = "" 3 lists = (1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1) 4 chars = ("M", "CM", "D", "CD", "C", "XC", "L", "XL

0013 罗马数字转整数

0013 罗马数字转整数 """ Roman numerals are represented by seven different symbols:?I, V, X, L, C, D and M. Symbol Value I 1 V 5 X 10 L 50 C 100 D 500 M 1000 For example,?two is written as II?in Roman numeral, just two one's added together. Twelve

C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数

各位相加 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数. 示例: 输入: 38 输出: 2 解释: 各位相加的过程为:3 + 8 = 11, 1 + 1 = 2. 由于 2 是一位数,所以返回 2. 进阶:你可以不使用循环或者递归,且在 O(1) 时间复杂度内解决这个问题吗? 题目地址 https://leetcode-cn.com/problems/add-digits/ 代码模板 public class Solution { public int AddDigits

LeetCode(13):罗马数字转整数

Easy! 题目描述: 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为两个并列的 1.12 写做 XII ,即为 X + II . 27 写做  XXVII, 即为 XX + V + II . 通常情况下,罗马数字中小的数字在大的数字的右边.但也存在特例,例如 4 不写做 IIII,而是 IV.数字 1 在数字 5 的左边,所表示的数等于大数 5 减小

LeetCode 13、罗马数字转整数

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值I 1V 5X 10L 50C 100D 500M 1000例如, 罗马数字 2 写做 II ,即为两个并列的 1.12 写做 XII ,即为 X + II . 27 写做  XXVII, 即为 XX + V + II . 通常情况下,罗马数字中小的数字在大的数字的右边.但也存在特例,例如 4 不写做 IIII,而是 IV.数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 .同样地,数字

Leetcode 13 罗马数字转整数

将每个罗马字母对应的整数写成字典格式,将输入的罗马数字字符串转换成列表形式 一开始想的是怎么将罗马字母的对应位置找出来,利用列表循环相加 后来发现了规律,'IV'和'I'+'V'只相差2,以此类推,最后将得到的总和减去多少个x里面的2就好了 def Rome(x): dict={ 'I':1, 'V':5, 'X':10, 'L':50, 'C':100, 'D':500, 'M':1000 } z=list(x) print(z) sum=0 for i in z: sum=sum+dict[

LeetCode题库13. 罗马数字转整数(c++实现)

问题描述: 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为两个并列的 1.12 写做 XII ,即为 X + II . 27 写做  XXVII, 即为 XX + V + II . 通常情况下,罗马数字中小的数字在大的数字的右边.但也存在特例,例如 4 不写做 IIII,而是 IV.数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得

【LeetCode 13】罗马数字转整数

题目链接 [题解] 就是上一题反过来的过程. 因为有说一般情况下后面的罗马数字是小于前面的罗马数字的. 如果前面的罗马数字小于后面的罗马数字了. 说明出现了4,9,40,90这些特殊情况. 那么就得判断一下下了. 直接用map<string,int>把所有的罗马数字对应的数字都放进去. 然后就很好做啦. 写的时候遇到一个问题. 就是string temp = 一个char类型+另外一个char类型变量. 会出错... 得这么写 string temp=""; temp+=c