LeetCode12. Integer to Roman不用任何数据结构和数组

Given an integer, convert it to a roman numeral.

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


class Solution {
public:
string intToRoman(int num) {
	if (num == 0) {
		return "";
	}
	else if (num == 1) {
		return "I";
	}
	else if (num <= 3) {
		return intToRoman(num - 1).append("I");
	}
	else if (num > 3 && num < 5) {
		return intToRoman(5-num).append("V");
	}
	else if (num == 5) {
		return "V";
	}
	else if (num > 5 && num <= 8) {
		return intToRoman(num - 1).append("I");
	}
	else if (num > 8 && num < 10) {
		return intToRoman(10 - num).append("X");
	}
	else if (num == 10) {
		return "X";
	}
	else if (num > 10 && num <= 30) {
		return string("X").append(intToRoman(num - 10));
	}
	else if (num == 40) {
		return "XL";
	}
	else if (num > 30 && num < 50) {
		return intToRoman(num / 10 * 10) + intToRoman(num % 10);
	}
	else if (num == 50) {
		return "L";
	}
	else if (num > 50 && num <= 80) {
		return string("L").append(intToRoman(num - 50));
	}
	else if (num == 90) {
		return "XC";
	}
	else if (num > 80 && num < 100) {
		return intToRoman(num / 10 * 10) + intToRoman(num % 10);
	}
	else if (num == 100) {
		return "C";
	}
	else if (num > 100 && num <= 300) {
		return string("C").append(intToRoman(num - 100));
	}
	else if (num == 400) {
		return "CD";
	}
	else if (num > 300 && num < 500) {
		return intToRoman(num / 100 * 100) + intToRoman(num % 100);
	}
	else if (num == 500) {
		return "D";
	}
	else if (num > 500 && num <= 800) {
		return string("D").append(intToRoman(num - 500));
	}
	else if (num == 900) {
		return "CM";
	}
	else if (num > 800 && num < 1000) {
		return intToRoman(num / 100 * 100) + intToRoman(num % 100);
	}
	else if (num == 1000) {
		return "M";
	}
	else if (num > 1000 && num <= 3000) {
		return string("M").append(intToRoman(num - 1000));
	}
	else {
		return intToRoman(num / 1000 * 1000) + intToRoman(num % 1000);
	}
}
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值