这是我的函数:
def listMaxInd(l):
max_val = l[0]
maxIndex = 0
count_assigment = 1
count_comparison = 0
for i in range(1,len(l)):
count_comparison=count_comparison+1
if l[i]>max_val:
max_val=l[i]
maxIndex=l.index(max_val)
count_assigment = count_assigment + 1
return maxIndex,count_assigment,count_comparison
我想通过仅分配索引而不是分配值来找到列表的最大值。
在我的版本中,我仍在分配值。没有这个,是否有可能找到最大值?
如果您需要使用循环并且无法使用 max()
函数,那么您至少需要分配指向到目前为止找到的最大值的索引:
max_index = 0
for i, value in enumerate(l):
if value > l[max_index]:
max_index = i
循环完成后,max_index
指向(第一次出现(l
中的最大值。 enumerate()
是一种更紧凑、更高效的方法,用于在循环中生成索引以及迭代的值。
更有效的方法是将 max()
函数与键一起使用:
max_index = max(range(len(l)), key=l.__getitem__)
这将返回列表l
中最大值的(第一个(索引;给定一个索引列表(range(len(l))
(,它将找到l.__getitem__()
返回最大值的索引。