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 语句判断是否是特殊情况,看起来就很繁琐了。

相关文章
|
4月前
|
算法
leetcode:389. 找不同
leetcode:389. 找不同
21 0
|
4月前
leetcode-475:供暖器
leetcode-475:供暖器
37 0
|
4月前
|
消息中间件 Kubernetes NoSQL
LeetCode 1359、1360
LeetCode 1359、1360
LeetCode 354. Russian Doll Envelopes
给定一些标记了宽度和高度的信封,宽度和高度以整数对形式 (w, h) 出现。当另一个信封的宽度和高度都比这个信封大的时候,这个信封就可以放进另一个信封里,如同俄罗斯套娃一样。 请计算最多能有多少个信封能组成一组“俄罗斯套娃”信封(即可以把一个信封放到另一个信封里面)。
77 0
LeetCode 354. Russian Doll Envelopes
|
存储
leetcode第52题
可以发现对于同一条副对角线,row + col 的值是相等的。 对于同一条主对角线,row - col 的值是相等的。 我们同样可以用一个 bool 型数组,来保存当前对角线是否有元素,把它们相加相减的值作为下标。 对于 row - col ,由于出现了负数,所以可以加 1 个 n,由 [ - 3, 3 ] 转换为 [ 1 , 7 ] 。
leetcode第52题
leetcode第53题
解法一和解法二的动态规划,只是在定义的时候一个表示以 i 开头的子数组,一个表示以 i 结尾的子数组,却造成了时间复杂度的差异。问题就是解法一中求出了太多的没必要的和,不如解法二直接,只保存最大的和。
leetcode第53题
|
算法
leetcode第45题
时间复杂度:O(n)。 空间复杂度:O(1)。 这里要注意一个细节,就是 for 循环中,i < nums.length - 1,少了末尾。因为开始的时候边界是第 0 个位置,steps 已经加 1 了。如下图,如果最后一步刚好跳到了末尾,此时 steps 其实不用加 1 了。如果是 i < nums.length,i 遍历到最后的时候,会进入 if 语句中,steps 会多加 1 。
leetcode第45题
leetcode第36题
一个 9 * 9 的数独的棋盘。判断已经写入数字的棋盘是不是合法。需要满足下边三点, • 每一行的数字不能重复 • 每一列的数字不能重复 • 9 个 3 * 3 的小棋盘中的数字也不能重复。 只能是 1 - 9 中的数字,不需要考虑数独最后能不能填满
leetcode第36题
|
算法
leetcode第47题
基本上都是在上道题的基础上改出来了,一些技巧也是经常遇到,比如先排序,然后判断和前一个是否重复。利用 Hash 去重的功能。利用原来的存储空间隐藏掉数据,然后再想办法还原。
leetcode第47题