leetcode第13题

简介: 解法一先来一种不优雅的,也就是我开始的想法。就是遍历字符串,然后转换就可以,但同时得考虑 IV,IX 那些特殊情况。

image.png

top13

和上一道题相反,将罗马数字转换成阿拉伯数字。

解法一

先来一种不优雅的,也就是我开始的想法。就是遍历字符串,然后转换就可以,但同时得考虑 IV,IX 那些特殊情况。

publicintgetInt(charr) {
intans=0;
switch (r) {
case'I':
ans=1;
break;
case'V':
ans=5;
break;
case'X':
ans=10;
break;
case'L':
ans=50;
break;
case'C':
ans=100;
break;
case'D':
ans=500;
break;
case'M':
ans=1000;
        }
returnans;
    }
publicintgetInt(charr, charr_after) {
intans=0;
switch (r) {
case'I':
ans=1;
break;
case'V':
ans=5;
break;
case'X':
ans=10;
break;
case'L':
ans=50;
break;
case'C':
ans=100;
break;
case'D':
ans=500;
break;
case'M':
ans=1000;
break;
        }
if (r=='I') {
switch (r_after) {
case'V':
ans=4;
break;
case'X':
ans=9;
            }
        }
if (r=='X') {
switch (r_after) {
case'L':
ans=40;
break;
case'C':
ans=90;
            }
        }
if (r=='C') {
switch (r_after) {
case'D':
ans=400;
break;
case'M':
ans=900;
            }
        }
returnans;
    }
publicbooleanisGetTwoInt(charr, charr_after) {
if (r=='I') {
switch (r_after) {
case'V':
returntrue;
case'X':
returntrue;
            }
        }
if (r=='X') {
switch (r_after) {
case'L':
returntrue;
case'C':
returntrue;
            }
        }
if (r=='C') {
switch (r_after) {
case'D':
returntrue;
case'M':
returntrue;
            }
        }
returnfalse;
    }
publicintromanToInt(Strings) {
intans=0;
for (inti=0; i<s.length() -1; i++) {
ans+=getInt(s.charAt(i), s.charAt(i+1));
//判断是否是两个字符的特殊情况if (isGetTwoInt(s.charAt(i), s.charAt(i+1))) {
i++;
            }
        }
//将最后一个字符单独判断,如果放到上边的循环会越界if (!(s.length() >=2&&isGetTwoInt(s.charAt(s.length() -2), s.charAt(s.length() -1)))) {
ans+=getInt(s.charAt(s.length() -1));
        }
returnans;
    }

解法二

https://leetcode.com/problems/roman-to-integer/description/

publicintromanToInt(Strings) {
intsum=0;
if(s.indexOf("IV")!=-1){sum-=2;}
if(s.indexOf("IX")!=-1){sum-=2;}
if(s.indexOf("XL")!=-1){sum-=20;}
if(s.indexOf("XC")!=-1){sum-=20;}
if(s.indexOf("CD")!=-1){sum-=200;}
if(s.indexOf("CM")!=-1){sum-=200;}
charc[]=s.toCharArray();
intcount=0;
for(;count<=s.length()-1;count++){
if(c[count]=='M') sum+=1000;
if(c[count]=='D') sum+=500;
if(c[count]=='C') sum+=100;
if(c[count]=='L') sum+=50;
if(c[count]=='X') sum+=10;
if(c[count]=='V') sum+=5;
if(c[count]=='I') sum+=1;
   }
returnsum;
}


把出现的特殊情况,提前减了就可以。

时间复杂度:O(1)。

空间复杂度:O(1)。


这道题也不难,自己一开始没有充分利用罗马数字的特点,而是用一些 if,switch 语句判断是否是特殊情况,看起来就很繁琐了。

相关文章
|
5月前
leetcode-472. 连接词
leetcode-472. 连接词
48 0
|
2月前
|
算法
LeetCode第66题加一
LeetCode第66题"加一"的解题方法,通过遍历数组从后向前处理每一位的加法,并考虑进位情况,最终实现给定数字加一的功能。
LeetCode第66题加一
|
5月前
LeetCode
LeetCode
37 0
|
5月前
leetcode-1219:黄金矿工
leetcode-1219:黄金矿工
75 0
|
存储 Python
LeetCode 66. Plus One
给定表示非负整数的非空数字数组,加上整数的1。 存储数字使得最高有效数字位于列表的开头,并且数组中的每个元素包含单个数字。 您可以假设整数不包含任何前导零,除了数字0本身。
88 0
LeetCode 66. Plus One
leetcode第39题
对回溯法又有了更深的了解,一般的架构就是一个大的 for 循环,然后先 add,接着利用递归进行向前遍历,然后再 remove ,继续循环。而解法二的动态规划就是一定要找到递进的规则,开始的时候就想偏了,导致迟迟想不出来。
leetcode第39题
|
算法
leetcode第47题
基本上都是在上道题的基础上改出来了,一些技巧也是经常遇到,比如先排序,然后判断和前一个是否重复。利用 Hash 去重的功能。利用原来的存储空间隐藏掉数据,然后再想办法还原。
leetcode第47题
|
算法
leetcode第40题
会发现出现了很多重复的结果,就是因为没有跳过重复的 1。在求 opt [ 1 ] 的时候就变成了 [ [ 1 ],[ 1 ] ] 这样子,由于后边求的时候都是直接在原来每一个列表里加数字,所有后边都是加了两次了。
leetcode第40题
leetcode第12题
相当简洁了,主要就是把所有的组合列出来,因为罗马数字表示的大小就是把所有字母相加,所以每次 append 那个,再把对应的值减去就行了。 时间复杂度:不是很清楚,也许是 O(1)?因为似乎和问题规模没什么关系了。 空间复杂度:O(1)
leetcode第12题