Roman numerals are a system of numerical notations used by the Romans. In this blog post I will be discussing a method to convert an integer into it’s equivalent Roman numeral representation. In Roman number system letter of Latin are used to represent the number. The letters and their corresponding values are as follows:
I: 1
V: 5
X: 10
L: 50
C: 100
D: 500
M: 1000
Numbers are formed by combining symbols together and adding the values. For example 1 is I, 12 is XII. However, in those cases when four successive character are coming to be same subtractive notation is used. For example 9 us not written as VIIII but as IX, 40 is not written as XXXX but as XL. Students are advised to visit the Wikipedia Page for Roman Numerals for details. There is no symbol for zero in Roman numeral system.
The problem which ICSE/ISC students usually face when writing a program to convert a positive integer into Roman numerals is how to handle the subtractive cases i.e. numbers like IX (9), XL(40), XC (90) etc. The first thought which comes to mind is to use a conditional statement but on closer inspection it turn out that it’s out that too many if statements would be required. It’s possible to solve the problem by using multiple if statement but there exists an elegant method also and that is to include subtractive cases also as follows:
I: 1
IV: 4
V: 5
IX: 9
X: 10
XL: 40
L: 50
XC: 90
C: 100
CD: 400
D: 500
CM: 900
M: 1000
In the above list we have included the subtractive cases viz.- 9, 40, 90, 400 and 900. Now, the logic is we have to divide out number by the largest factor first (1000), the corresponding symbol will be repeated quotient times, the remainder will then become the number for future division and repetitions. The process will be repeated until the number becomes zero. For example- if the number is 2015, we will divide it by 1000, the quotient and remainder would be 2 and 15 respectively. The corresponding symbol M will be repeated twice. The remainder 15 will now be completely divisible by 10, the quotient and remainder would be 1 and 5 respectively. The corresponding symbol X will be added to the answer which will now become MMX. The remainder 5 will now be completely divisible by 5, the quotient and remainder would be 1 and 0 respectively. The corresponding symbol X will be added to the answer which will now become MMXV. The remainder is now 0 and therefore we will stop. A primitive version using the above logic is as follows:
class Roman{ public static String IntegerToRoman(int n){ String roman=""; int repeat; repeat=n/1000; for(int i=1; i<=repeat;i++){ roman=roman+"M"; } n=n%1000; repeat=n/900; for(int i=1; i<=repeat;i++){ roman=roman+"CM"; } n=n%900; repeat=n/500; for(int i=1; i<=repeat;i++){ roman=roman+"D"; } n=n%500; repeat=n/400; for(int i=1; i<=repeat;i++){ roman=roman+"CD"; } n=n%400; repeat=n/100; for(int i=1; i<=repeat;i++){ roman=roman+"C"; } n=n%100; repeat=n/90; for(int i=1; i<=repeat;i++){ roman=roman+"XC"; } n=n%90; repeat=n/50; for(int i=1; i<=repeat;i++){ roman=roman+"L"; } n=n%50; repeat=n/40; for(int i=1; i<=repeat;i++){ roman=roman+"XL"; } n=n%40; repeat=n/10; for(int i=1; i<=repeat;i++){ roman=roman+"X"; } n=n%10; repeat=n/9; for(int i=1; i<=repeat;i++){ roman=roman+"IX"; } n=n%9; repeat=n/5; for(int i=1; i<=repeat;i++){ roman=roman+"V"; } n=n%5; repeat=n/4; for(int i=1; i<=repeat;i++){ roman=roman+"IV"; } n=n%4; repeat=n/1; // or simply repeat=n or i<=n in the condition part of the loop for(int i=1; i<=repeat;i++){ roman=roman+"I"; } return roman; } public static void main(String args[]){ System.out.println("12: "+IntegerToRoman(12)); System.out.println("999: "+IntegerToRoman(999)); } }
Students of class 10 and above should notice that the size of the program can be drastically reduced if we use an array to store the symbols and magnitudes. The array version using the same logic is as follows:
class Roman{ public static String IntegerToRoman(int n){ String roman=""; int repeat; int magnitude[]={1000,900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1}; String symbol[]={"M","CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"}; for(int x=0; x<magnitude.length; x++){ repeat=n/magnitude[x]; for(int i=1; i<=repeat; i++){ roman=roman + symbol[x]; } n=n%magnitude[x]; } return roman; } public static void main(String args[]){ System.out.println("12: "+IntegerToRoman(12)); System.out.println("999: "+IntegerToRoman(999)); } }
As usual, the main function has purposely been kept to minimum and its expected that students will write appropriate input/output statements as per the requirement.
An easy way to check the answer is to type the following in the Google search bar/page:
12 in roman
🙂
Thanks Sir for this wonderful blog. After a long time I once again attended your class through your blog. Thanks.
Nice to hear from you! However, I doubt that this blog will be useful to you now at this stage! 🙂
No sir, its still useful in point of logic and problem solving, as it enhance basic and foundation logic of coding…
No need for the repeat=n/1;
You are right. I have added a comment mentioning the same in the first solution. The first solution is just for reiterating the underlying concept only and for all practical purposes second solution is preferred.
can you explain me this program?
Thank you you very much.
Amazing to see such wonderful and crisp code to convert numbers into Roman letters! Thank yo for sharing it