使用Python创建Euler 17项目

2024-06-25 23:32:53 发布

您现在位置:Python中文网/ 问答频道 /正文

我目前正在用Python解决projecteuler的第17个问题。以下是问题陈述的链接:

http://projecteuler.net/problem=17

下面是我的Python解决方案:

def no_to_words(n):
    num = str(n)
    s = ""
    hunds = n/100
    ten = n%100
    tens = ten/10
    units = ten%10
    if(len(num) == 3):
        if(n == 100):
            return "one hundred"

        if(hunds == 1):                        
            s = s + "one hundred and"
        elif(hunds == 2):
            s = s + "two hundred and"
        elif(hunds == 3):
            s = s + "three hundred and"
        elif(hunds == 4):
            s = s + "four hundred and"
        elif(hunds == 5):
            s = s + "five hundred and"
        elif(hunds == 6):
            s = s + "six hundred and"
        elif(hunds == 7):
            s = s + "seven hundred and"
        elif(hunds == 8):
            s = s + "eight hundred and"
        else:
            s = s + "nine hundred and"

        if(ten == 11):                         
            s = s + " eleven"
            return s
        elif(ten == 12):
            s = s + " twelve"
            return s
        elif(ten == 13):
            s = s + " thirteen"
            return s
        elif(ten == 14):
            s = s + " fourteen"
            return s
        elif(ten == 15):
            s = s + " fifteen"
            return s
        elif(ten == 16):
            s = s + " sixteen"
            return s
        elif(ten == 17):
            s = s + " seventeen"
            return s
        elif(ten == 18):
            s = s + " eighteen"
            return s
        elif(ten == 19):
            s = s + " nineteen"
            return s

        if(tens == 2):
            s = s + " twenty"
        elif(tens == 3):
            s = s + " thirty"
        elif(tens == 4):
            s = s + " forty"
        elif(tens == 5):
            s = s + " fifty"
        elif(tens == 6):
            s = s + " sixty"
        elif(tens == 7):
            s = s + " seventy"
        elif(tens == 8):
            s = s + " eighty"
        elif(tens == 9):
            s = s + " ninety"

        if(units == 1):                         
            s = s + " one"
        elif(units == 2):
            s = s + " two"
        elif(units == 3):
            s = s + " three"
        elif(units == 4):
            s = s + " four"
        elif(units == 5):
            s = s + " five"
        elif(units == 6):
            s = s + " six"
        elif(units == 7):
            s = s + " seven"
        elif(units == 8):
            s = s + " eight"
        elif(units == 9):
            s = s + " nine"

    if(len(num) == 2):
        if(n == 10):
            return "ten"
        if(ten == 11):                         
            s = s + "eleven"
            return s
        elif(ten == 12):
            s = s + "twelve"
            return s
        elif(ten == 13):
            s = s + "thirteen"
            return s
        elif(ten == 14):
            s = s + "fourteen"
            return s
        elif(ten == 15):
            s = s + "fifteen"
            return s
        elif(ten == 16):
            s = s + "sixteen"
            return s
        elif(ten == 17):
            s = s + "seventeen"
            return s
        elif(ten == 18):
            s = s + "eighteen"
            return s
        elif(ten == 19):
            s = s + "nineteen"
            return s


        if(tens == 2):
            s = s + "twenty"
        elif(tens == 3):
            s = s + "thirty"
        elif(tens == 4):
            s = s + "forty"
        elif(tens == 5):
            s = s + "fifty"
        elif(tens == 6):
            s = s + "sixty"
        elif(tens == 7):
            s = s + "seventy"
        elif(tens == 8):
            s = s + "eighty"
        elif(tens == 9):
            s = s + "ninety"

        if(units == 1):
            s = s + " one"
        elif(units == 2):
            s = s + " two"
        elif(units == 3):
            s = s + " three"
        elif(units == 4):
            s = s + " four"
        elif(units == 5):
            s = s + " five"
        elif(units == 6):
            s = s + " six"
        elif(units == 7):
            s = s + " seven"
        elif(units == 8):
            s = s + " eight"
        elif(units == 9):
            s = s + " nine"

    if(len(num) == 1):
        if(units == 1):
            s = "one"
        elif(units == 2):
            s = "two"
        elif(units == 3):
            s = "three"
        elif(units == 4):
            s = "four"
        elif(units == 5):
            s = "five"
        elif(units == 6):
            s = "six"
        elif(units == 7):
            s = "seven"
        elif(units == 8):
            s = "eight"
        elif(units == 9):
            s = "nine"

    if(len(num) == 4):
        return "one thousand"

    return s

final = ""
for e in range(1, 1001):
    s = no_to_words(e)
    final = final + s
ultimate = final.replace(" ", "")
print len(ultimate)

现在,这个问题的答案是(扰流器):

21124

然而,我的答案是21121。我的代码怎么了?我好像搞不懂这个问题。你知道吗


Tags: andlenreturnifonenumthreefour
2条回答

你好像在重新发明轮子。我使用了num2words库,而不是不使用单词。这似乎给了我正确的答案。你知道吗

total = 0
for num in range(1, 1001):
    total += len(num2words(num).replace(" ", "").replace("-", ""))

print(total)
21124

你从未涉及过tens==1的情况。你不需要考虑100的精确倍数。你知道吗

相关问题 更多 >