【LeetCode 13】罗马数字转整数

题目链接

【题解】

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

【代码】

class Solution {
public:
    int romanToInt(string s) {
        map<string,int> dic;
        dic.clear();
        int nums[]={1,4,5,9,10,40,50,90,100,400,500,900,1000};
        string roma[]={"I","IV","V","IX","X","XL","L","XC","C","CD","D","CM","M"};
        for (int i = 0;i < 13;i++) dic[roma[i]] = nums[i];
        int len = s.size();
        int ans = 0;
        for (int i = 0;i < len;i++){
            string chara = "";string charb = "";
            chara+=s[i];
            if (i<len-1) charb +=s[i+1];
            if (i<len-1 && dic[chara]<dic[charb]){
                string temp = "";
                temp+=chara;temp+=charb;
                ans = ans + dic[temp];
                i++;
            }else ans+=dic[chara];
        }
        return ans;
    }
};

原文地址:https://www.cnblogs.com/AWCXV/p/11802551.html

时间: 2024-10-18 21:56:01

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

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. 罗马数字转整数

class Solution: def romanToInt(self, s: str) -> int: memo={'I':1,'IV':4,'V':5,'IX':9,'X':10,'XL':40,'L':50,'XC':90,'C':100,'CD':400,'D':500,'CM':900,'M':1000} i=0 v=0 while i<len(s): if i<len(s)-1 and s[i] in ['I','X','C']: if s[i:i+2] in ['IV','

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

LeetCode:罗马数字转整数[13] 题目描述 罗马数字包含以下七种字符: 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 的左边

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 得

13.罗马数字转整数

class Solution: def romanToInt(self, s: str) -> int: # 将各个字母表示的数字存入字典中 numeral_map = {"I":1,"V":5,"X":10,"L":50,"C":100,"D":500,"M":1000} # 存储罗马字母转成的整数值 result = 0 for i in range(len

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 得到的数

第13题:整数转换成罗马数字&amp;第14题:罗马数字转换成整数

写在前面: 这两道题合起来写吧,其实整数转罗马数字我前天就写完了,当我想写罗马数转整数的时候竟然脑子一片空白,想了几分钟就想起来Map,本着学习的目的最终还是不想用Map,坚持C语言,今天脑子里直接涌出了Switch方式转换,看来"蹲在马桶上编程"的方式还是蛮不错的o(^▽^)o 整数转罗马数字:主要建立对应关系,输出时有点像百钱百鸡 罗马数字转整数:输入罗马数字(其实就是字符数组)后,for循环遍历,找出对应,这个再看不懂的建议去看看罗马数字表示方法. 第13题:整数转换成罗马数字

罗马数字与整数相互转化

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

Leetcode 13. Roman to Integer C语言

Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 to 3999. 罗马数字与整数互转 int getInt(char c){     int temp;     switch(c){         case 'I':return 1;         case 'V':return 5;         case 'X':return 10;  

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