【发布时间】:2014-08-03 12:21:15
【问题描述】:
我需要编写一个以列表为参数的函数,并在列表中找到第二高的值。返回该值。如果列表中只有一个值,则返回该值。如果列表为空,则返回 0。
要创建列表,我会提示用户输入数字,直到用户输入标记值 -1。然后我提示用户输入起始位置 (loc) 和长度 (len)。我将提取一个从索引 loc 开始并且长度为 len 的列表切片,然后使用我的函数查找该列表切片中的第二高值。
这是我目前的代码:
userList = []
def main():
inputList = int(input("Enter a number >= 0. Enter -1 to end input: "))
while inputList != -1:
userList.append(inputList)
inputList = eval(input("Enter a number >= 0. Enter -1 to end input: "))
return extractList(userList)
def extractList(userList):
loc = int(input("Enter a starting location: "))
length = int(input("Enter a lenghth: "))
selSlice = userList[loc:loc + length]
if len(selSlice) == 1:
return selSlice[0]
if len(selSlice) == 0:
return 0
num = max(selSlice)
occ = userList.count(num)
for i in range(occ):
userList[userList.index(num):userList.index(num)+1] = ''
print("Second highest value in ", selSlice, "is ", max(selSlice))
main()
我正在测试切片是否有效,但它似乎采用 loc 的起始索引并转到 len 的结束索引而不是 len 的长度。
例如,如果我有一个列表:
[1, 3, 7, 21, 37, 76, 23, 91, 15, 11, 2, 4]
我的loc 是3,我的len 是6,结果应该是[21, 37, 76, 23, 91, 15]。但是,我没有得到这个想要的结果,而是得到[21, 37, 76]。
我的extractList(a) 应该是什么?另外,如果您能帮助我找到第二高值的功能,那就太好了。感谢您的任何意见!
编辑:
好的,感谢Chris Arena 和To Click or Not to Click,我现在走在了正确的轨道上。 (代码已更新)
但是,上面的代码给了我整个列表的第二高值,而不是切片列表。我不确定是否所有变量都正确。
如果我的 userList 是 [1, 3, 5, 7, 9, 2, 4, 6, 8, 10] 并且我的 loc 是 6 并且长度是 4,我应该得到 [4, 6, 8, 10],但切片的第二高值是 9,这是第二高的用户列表,而不是切片。
我尝试将userList 更改为selSlice,从if len(userList) == 1: 行开始一直到最后,看看是否有所不同。确实如此,但结果是有问题的(也就是错误的)。我使用了与上一段中提到的相同的 userList、loc 和 length。我得到了[4, 6, 8] 作为切片(错误),第二高的值为 8,这对于程序返回的切片是错误的,但对于我请求的切片是正确的。所以我不确定这里可能有什么问题。有什么建议吗?
编辑到编辑:
我的最新代码显示了正确的切片,但第二高值错误。我越来越:
Second highest value in [4, 6, 8, 10] is 10 不确定需要修复什么=\
【问题讨论】:
-
不要不必要地
eval,这会导致邪恶的事情发生。 -
我认为在我的代码中没有必要,除非有其他方法可以获取用户输入的数字
-
@devnull true, @annabananana7 试试
ast.literal_eval -
旁白:这与您的主要问题无关,但重复您的“输入数字”文本是一种常见的反模式。您可以阅读this question 了解原因。
-
@DSM 谢谢!下次我会尽量记住这一点:)
标签: python list python-3.x slice