Given an integer, convert it to a roman numeral.
Input is guaranteed to be within the range from 1 to 3999.
store the roman and values in arrays and iterate array to get the value. takes O(1) space and O(n) time
class Solution(object): def intToRoman(self, num): """ :type num: int :rtype: str """ values = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1] roman = ['M', 'CM', 'D', 'CD', 'C', 'XC', 'L', 'XL', 'X', 'IX', 'V', 'IV', 'I'] result = '' for index in range(len(values)): while num >= values[index]: result += roman[index] num -= values[index] return result