从数字转换为罗马符号

时间:2015-11-02 20:24:18

标签: python loops while-loop converter roman-numerals

我想将数字转换为罗马符号。我得到了一个如下所示的列表:

conv = [[1000, 'M'], [900, 'CM'], [500, 'D'], [400, 'CD'],
        [ 100, 'C'], [ 90, 'XC'], [ 50, 'L'], [ 40, 'XL'],
        [  10, 'X'], [  9, 'IX'], [  5, 'V'], [  4, 'IV'],
        [   1, 'I']]

其中input应该是0到3999之间的整数。所以我想构造一个接受参数(整数)并转换它的函数。解决这个问题我有点问题。任何帮助,将不胜感激。以下是我的想法:

首先,我想要一个存储在变量中的整数输入,所以我会使用像

这样的东西
number = input("Enter a number between 0 and 3999: ")

conv = [[1000, 'M'], [900, 'CM'], [500, 'D'], [400, 'CD'],
        [ 100, 'C'], [ 90, 'XC'], [ 50, 'L'], [ 40, 'XL'],
        [  10, 'X'], [  9, 'IX'], [  5, 'V'], [  4, 'IV'],
        [   1, 'I']]

对于最后一步,我想使用2个循环来解决实际问题。看起来像这样:

for char in number:
    i = 0;
    while i < len(conv):
        if int(char) == int(conv[i][0]):
            print(conv[i][1])
            i += 1;
        else:
            i += 1;

我知道这段代码错了,但也许不是这个想法。首先,我想循环遍历字符串编号中的每个'char'(字符)。为此,我还将定义一个变量'i',我将其设置为0.此变量'i'将在while循环中使用,只要i小于list conv的长度,就应该执行该循环。然后我想比较整数char是否等于index [i] [0]处的conv的整数部分(0因为我总是想要与列表中的数字部分进行比较而我因为我想循环遍历每一个可能性如果他们匹配,那么我想做点什么,我真的不知道我想在这一步做什么,但我想打印一些东西。在这一步我想告诉程序构建罗马符号并且还增加i。否则只是递增i。我必须让程序理解12表示为XII,依此类推。任何想法如何解决这个问题。谢谢:)

2 个答案:

答案 0 :(得分:5)

我是这样做的。该程序循环遍历conv数组,每一步都将相应的罗马数字附加到result

def arabic_to_roman(number):
    conv = [[1000, 'M'], [900, 'CM'], [500, 'D'], [400, 'CD'],
            [ 100, 'C'], [ 90, 'XC'], [ 50, 'L'], [ 40, 'XL'],
            [  10, 'X'], [  9, 'IX'], [  5, 'V'], [  4, 'IV'],
            [   1, 'I']]
    result = ''
    for denom, roman_digit in conv:
        result += roman_digit*(number/denom)
        number %= denom
    return result

for i in 1,4,9,16,25,49,81,1963,2015:
    print i, arabic_to_roman(i)

答案 1 :(得分:2)

这是一个超级简单的程序,可以根据需要进行转换:

>>> num = 1423
>>> roman = ''
>>> i = 0 #initiate i = 0
>>> while num > 0:
    while conv[i][0] > num: i+=1 #increments i to largest value greater than current num
    roman += conv[i][1] #adds the roman numeral equivalent to string
    num -= conv[i][0] #decrements your num


>>> roman
'MCDXXIII'