Python 最大相邻数-值的增量不正确
我写这个程序是为了找到这个数字中13个相邻的数字,当它们相加时,它们的总和最大。但是,当我运行它时,b值不是从12开始的;它从一个非常高的数字开始,我不知道为什么。知道为什么我的a和b值不能正确递增吗Python 最大相邻数-值的增量不正确,python,increment,Python,Increment,我写这个程序是为了找到这个数字中13个相邻的数字,当它们相加时,它们的总和最大。但是,当我运行它时,b值不是从12开始的;它从一个非常高的数字开始,我不知道为什么。知道为什么我的a和b值不能正确递增吗 num = "7316717653133062491922511967442657474235534919493496983520312774506326239578318016984801869478851843858615607891129494954595017379583319528532
num = "731671765313306249192251196744265747423553491949349698352031277450632623957831801698480186947885184385861560789112949495459501737958331952853208805511125069874715852386305071569329096329522744304355766896648950445244523161731856403098711121722383113622298934233803081353362766142828064444866452387493035890729629049156044077239071381051585930796086670172427121883998797908792274921901699720888093776657273330010533678812202354218097512545405947522435258490771167055601360483958644670632441572215539753697817977846174064955149290862569321978468622482839722413756570560574902614079729686524145351004748216637048440319989000889524345065854122758866688116427171479924442928230863465674813919123162824586178664583591245665294765456828489128831426076900422421902267105562632111110937054421750694165896040807198403850962455444362981230987879927244284909188845801561660979191338754992005240636899125607176060588611646710940507754100225698315520005593572972571636269561882670428252483600823257530420752963450"
a = 0
b = 12
greatest = 0
while b != len(str(num)):
num = str(num)
newNum = num[a:b]
total = 0
for num in newNum:
num = int(num)
total += num
if total > greatest:
greatest = total
a+=1
b+=1
print(b)
print(greatest)
主要问题是您在内部循环中重用
num
,这会在第一次运行后使“原始”num
错误
另外,如果你想让一个13
数字运行,最好从b=13开始
而且,由于它已经是一个字符串,因此不需要str(num)
,也不需要在程序中更改b
。您还可以在map
时使用sum
替换内部循环
以下是这些更改后的外观:
num = "731671765313306249192251196744265747423553491949349698352031277450632623957831801698480186947885184385861560789112949495459501737958331952853208805511125069874715852386305071569329096329522744304355766896648950445244523161731856403098711121722383113622298934233803081353362766142828064444866452387493035890729629049156044077239071381051585930796086670172427121883998797908792274921901699720888093776657273330010533678812202354218097512545405947522435258490771167055601360483958644670632441572215539753697817977846174064955149290862569321978468622482839722413756570560574902614079729686524145351004748216637048440319989000889524345065854122758866688116427171479924442928230863465674813919123162824586178664583591245665294765456828489128831426076900422421902267105562632111110937054421750694165896040807198403850962455444362981230987879927244284909188845801561660979191338754992005240636899125607176060588611646710940507754100225698315520005593572972571636269561882670428252483600823257530420752963450"
index = 0
run_in = 13
greatest = 0
while index + run_in < len(num):
num_slice = num[index: index + run_in]
slice_sum = sum(map(int, num_slice))
if slice_sum > greatest:
greatest = slice_sum
index += 1
print(greatest)
def最大值(num,k):
num=str(num)
if len(num)answer[0]:answer=currsum,i
i+=1
回覆
总计,ind=最大值(myNum,13)
打印(“数字的最大和为{},从索引{}开始”。格式(总计,ind))
不重新定义num
并用其他单词代替其他变量如何?不要在同一范围内重复使用变量名。另外,b
从12开始就可以了。@ev。要不然我怎么写呢?@user2357112在我运行它的时候不是。也许我的pycharm解释器坏了
greatest = max(sum(map(int, num[index: index + run_in])) for index in range(len(num) - run_in))
def largest(num, k):
num = str(num)
if len(num) < k: raise ValueError("Need a number with at least {} digits".format(k))
currsum = sum(int(i) for i in num[:k])
answer = currsum, 0
i = k+1
while i < len(num):
currsum -= int(num[i-k])
currsum += int(num[i])
if currsum > answer[0]: answer = currsum, i
i += 1
return answer
total, ind = largest(myNum, 13)
print("The maximum sum of digits is {}, starting at index {}".format(total, ind))