LeetCode 13. Roman to Integer(java)

Given a roman numeral, convert it to an integer.
Input is guaranteed to be within the range from 1 to 3999.
例如:”DCXXI” -> 621

思路:这道题主要是找到罗马字符和数字间的对应关系,下面是4000以内的罗马字符和数字的对应表:
String[] num1 = {“I”,”II”,”III”,”IV”,”V”,”VI”,”VII”,”VIII”,”IX”};
String[] num10 = {“X”, “XX”,”XXX”,”XL”,”L”,”LX”,”LXX”,”LXXX”,”XC”};
String[] num100 = {“C”,”CC”,”CCC”,”CD”,”D”,”DC”,”DCC”,”DCCC”,”CM”};
String[] num1000 = {“M”,”MM”,”MMM”};

解法一:

我们发现, IV = 4 = (5 + 1) - 2 = V + I - 2, IX = 9 = (10 + 1) - 2 = X + I - 2. 因此,我们每次遇到IV, IX等同类型的字符,就让sum减去相应的数字,然后将string s分成char类型的数组,每个字符都在sum中加上相应的数字。由于indexOf()方法的时间复杂度是O(n),因此,此方法的时间复杂度为O(6n),空间复杂度为O(n).
代码:

public int romanToInt(String s) {
        int sum = 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;
        char[] c = s.toCharArray();
        for(int i = 0; i < c.length; i++) {
            if (c[i] == 'I') sum += 1;
            if (c[i] == 'V') sum += 5;
            if (c[i] == 'X') sum += 10;
            if (c[i] == 'L') sum += 50;
            if (c[i] == 'C') sum += 100;
            if (c[i] == 'D') sum += 500;
            if (c[i] == 'M') sum += 1000;
        }
        return sum;
    }
解法二:(最优解法)

思路:如果前一个字符代表的数字比后一个小,则sum减去它代表的数字;如果比后一个大,则加上它代表的数字。用hashmap来做,因此每次查找的时间为O(1),时间复杂度为O(n),空间复杂度为O(1)

public static int romanToInt(String s) {
        if (s == null || s.length() == 0)
            return -1;
        HashMap<Character, Integer> map = new HashMap<Character, Integer>();
        map.put('I', 1);
        map.put('V', 5);
        map.put('X', 10);
        map.put('L', 50);
        map.put('C', 100);
        map.put('D', 500);
        map.put('M', 1000);
        int len = s.length(), result = map.get(s.charAt(len - 1));
        for (int i = len - 2; i >= 0; i--) {
            if (map.get(s.charAt(i)) >= map.get(s.charAt(i + 1)))
                result += map.get(s.charAt(i));
            else
                result -= map.get(s.charAt(i));
        }
        return result;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值