[LeetCode]12. Integer to Roman(自学留存)

Given an integer, convert it to a roman numeral.

Input is guaranteed to be within the range from 1 to 3999.



Personal Tips: 使用map,记录1,5,10,50,100,500,1000分别对应的罗马数字,以及其规则。代码如下:

class Solution
{
public:
	Solution()
	{
		RomanTable.insert(pair<int, char>(1, 'I'));
		RomanTable.insert(pair<int, char>(5, 'V'));
		RomanTable.insert(pair<int, char>(10, 'X'));
		RomanTable.insert(pair<int, char>(50, 'L'));
		RomanTable.insert(pair<int, char>(100, 'C'));
		RomanTable.insert(pair<int, char>(500, 'D'));
		RomanTable.insert(pair<int, char>(1000, 'M'));
	}
	string intToRoman(int num) {
		string Roman;
		int count = 1000;
		while (count>0)
		{
			Roman.append(getSingleNum(num / count, count));
			num -= (num / count)*count;
			count /= 10;
		}
		return Roman;
	}
	inline string getSingleNum(int num, int count) {
		string singleRoman;
		if (num<4) return singleRoman.append(num, RomanTable[count]);
		else if (num <= 5)
		{
			singleRoman.append(5 - num, RomanTable[count]);
			singleRoman.append(1, RomanTable[5 * count]);
		}
		else if (num<9)
		{
			singleRoman.append(1, RomanTable[5 * count]);
			singleRoman.append(num - 5, RomanTable[count]);
		}
		else if (num == 9)
		{
			singleRoman.append(1, RomanTable[count]);
			singleRoman.append(1, RomanTable[10 * count]);
		}
		return singleRoman;
	}
private:
	map<int, char> RomanTable;
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值