LeetCode No.13. 罗马数字转整数

##一般的循环解法
int romanToInt(string s) {
        int result=0;
        map<char,int> map={
            {'I',1},
            {'V',5},
            {'X',10},
            {'L',50},
            {'C',100},
            {'D', 500},
            {'M', 1000}
        };//初始化哈希表
        for(int i=0;i<s.length();i++)
        {
            if(map[s[i]] < map[s[i+1]]) //如果该字符比后一个字符小,则减去该字符的数字
                result -= map[s[i]];
            else
            {
                result += map[s[i]]; //否则加上该字符的数字
            }
        }
        return result;
    }
##采用递归解法
class Solution {
public:
	int digitsToVlaue(char ch) {  //可以用hash map优化掉
		for (int i = 0; i < 7; i++) {
			if (digits[i] == ch) return values[i];
		}
		return 0;
	}

	int maxIndex(char* str, int L, int R) { //获取最大字符
		int max = digitsToVlaue(str[L]);
		int maxIndex = L;
		for (int i = L; i <= R; i++) {
			int m= digitsToVlaue(str[i]);
			if (m > max) {
				max = m;
				maxIndex = i;
			}
		}
		return maxIndex;
	}

	int romanToNumber(char str[],int L, int R) {
		if (L == R) return digitsToVlaue(str[L]);
		if (L > R) return 0;

		int mi = maxIndex(str,L,R);
		int max = digitsToVlaue(str[mi]);
		int left = romanToNumber(str, L, mi - 1); //递归的算坐标的式子
		int right = romanToNumber(str, mi + 1, R); //递归的算右边的式子
		return max - left + right;
	}

private:
	char digits[7] = { 'I','V','X','L','C','D','M' };
	int  values[7] =  { 1,  5, 10,  50,100,500,1000 };
};

类似:LeetCode No.12. 整数转罗马数字

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值