1

我正在编写一些代码来练习 Python 编程。代码如下:

#! /usr/bin/python

string ='''
73167176531330624919225119674426574742355349194934
96983520312774506326239578318016984801869478851843
85861560789112949495459501737958331952853208805511
12540698747158523863050715693290963295227443043557
66896648950445244523161731856403098711121722383113
62229893423380308135336276614282806444486645238749
30358907296290491560440772390713810515859307960866
70172427121883998797908792274921901699720888093776
65727333001053367881220235421809751254540594752243
52584907711670556013604839586446706324415722155397
53697817977846174064955149290862569321978468622482
83972241375657056057490261407972968652414535100474
82166370484403199890008895243450658541227588666881
16427171479924442928230863465674813919123162824586
17866458359124566529476545682848912883142607690042
24219022671055626321111109370544217506941658960408
07198403850962455444362981230987879927244284909188
84580156166097919133875499200524063689912560717606
05886116467109405077541002256983155200055935729725
71636269561882670428252483600823257530420752963450'''.replace('\n','')

sum1 = 1
lis = [0,1,2,3,4]
lis2 = list()
while(1):
    for j in range(5):
        sum1 *= int(string[ lis[j] ])
    lis2.append(sum1)
    sum1 = 1
    for k in range(5):
        lis[k] = lis[k] + 1
    if lis[4] == 999:
        break
lis2.sort() 
print lis2

该程序用于在 1000 位数字中找到五个连续数字的最大乘积。

但是程序没有用!一个错误

ValueError: invalid literal for int() with base 10:

当我运行程序时发生了!

我是python的新手!

4

3 回答 3

4

帮助教你如何为自己钓鱼:

错误说“你传入的int()实际上不是一个整数”,所以在你尝试int()它之前,你打印它怎么样。print string[ lis[j] ]. 这应该可以帮助您调试问题。

无论如何都会给鱼:

问题是您试图将换行符 ( \n) 转换为整数。正如@steveha 建议使用.replace()

于 2012-04-19T03:39:31.663 回答
3

您的问题很简单:Python 三引号字符串包含行尾。每行末尾都有一个“换行符”字符,int()不高兴。

最简单的解决方案是使用字符串.replace()方法删除不需要的换行符。我们使用"\n"换行符:

string = """
012345
242432
234323""".replace('\n', '')

在我进行更改后,您的程序仍然无法运行,但那个特定问题已经消失了。

编辑:为了改进您的程序,我建议您阅读 Python 中字符串的“切片”。您可以使用切片从输入字符串中一次抓取 5 个字符。此外,Python 可以使用普通for循环遍历字符串,因此您可以获得 5 个字符的切片并对其进行循环以将五个数字相乘。

于 2012-04-19T03:36:40.043 回答
1

指定字符串的更好方法是这样的。较小的字符串将在编译时连接,并且在运行时不需要进一步处理

mystring = (
    '73167176531330624919225119674426574742355349194934'
    '96983520312774506326239578318016984801869478851843'
    '85861560789112949495459501737958331952853208805511'
    ...
    '71636269561882670428252483600823257530420752963450')

剧透(rot13)。这将给出构成最大产品的数字

>>> zlqvtvgf = znc(vag, zlfgevat)
>>> qrs cebq((n,o,p,q,r)): erghea n*o*p*q*r
... 
>>> znk((zlqvtvgf[v:v+5] sbe v va enatr(yra(zlfgevat)-4)), xrl=cebq)
[9, 9, 8, 7, 9]
于 2012-04-19T04:33:21.533 回答