如何解决在不使用列表的情况下计算 10 个整数之间的最大增量
我有一个问题集需要解决,但无法想象如何使用我目前知道的工具解决这个问题。有人可以就我应该如何解决这个问题提供一些指导吗?
问题集:
Design a program to compute the largest increase that occurred in a list of 10 numbers. Note: Your design cannot assign a separate variable per number nor can you use a list.
The program should read any 10 integers and print a result:
Numbers : 48 54 49 47 62 64 79 80 82 84
Largest increase of 15
from 64 to 79
occurred between day 6 and day 7
在我看来 - 我会通过将数字转换为列表并遍历列表来比较天数之间的差异来解决这个问题。如果下一组天数的差异大于前一组天数,则将替换该值。
从那里我将在 Largest increase of ____
中输入我的迭代的最终值。
然而..因为我不能使用列表,所以我不完全确定如何解决这个问题。
解决方法
您可以使用迭代器代替列表,例如:
from itertools import tee
numbers = [48,54,49,47,62,64,79,80,82,84]
a,b = tee(numbers)
next(b,None)
maxnum,argmax = max(map(lambda x: (x[1][1] - x[1][0],x[0]),enumerate(zip(a,b))))
print(maxnum,(numbers[argmax],numbers[argmax + 1]))
输出:
15 (64,79)
使用以下方法解决问题:
- python 内置函数
-
enumerate
用于迭代计数和值 -
zip
用于聚合多个迭代器的值 -
map
用于将函数应用于迭代器的每一项
-
- 模块
itertools
和带有tee
函数的“Itertools Recipe”用于遍历对,参见 https://docs.python.org/3/library/itertools.html#itertools-recipes -
max
函数中的元组比较。元组(increas,increase position)
的比较用于获得最后的最大增量。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。