C++算法:罗马数字转整数

leetcode相关C++算法解答: https://github.com/Nereus-Minos/C_plus_plus-leetcode

罗马数字转整数

代码:

	//建立一个哈希表,然后一一判断,若前面的罗马数值比后面的罗马数值小,则将结果加上两者的正差值,若前面的罗马数值比后面的罗马数值大,则直接加上该罗马的对应数值。

	class Solution {
	public:
		int romanToInt(string s) {
			int result=0;//存放结果
			map<char,int> luomab;//建立罗马表
			//插入对应关系
			luomab.insert(map<char,int>::value_type('I',1));
			luomab.insert(map<char,int>::value_type('V',5));
			luomab.insert(map<char,int>::value_type('X',10));
			luomab.insert(map<char,int>::value_type('L',50));
			luomab.insert(map<char,int>::value_type('C',100));
			luomab.insert(map<char,int>::value_type('D',500));
			luomab.insert(map<char,int>::value_type('M',1000));
			for(int i=0;i<s.length();i++)
			{
				if(luomab[s[i]]>=luomab[s[i+1]])
					result+=luomab[s[i]];
				else
				{
					result+=(luomab[s[i+1]]-luomab[s[i]]);
					i++;
				}
			}
			return result;
		}
	};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值