有人可以向我解释这个python循环如何输出列表中元素的相反顺序吗?这是学校作业的一部分,我无法完全理解其工作原理。
我知道这是获取列表反向顺序的一种更困难的方法,但是我们不允许使用反向功能,而且我似乎无法使列表拼接通过自动分级器。
def reverse_list(stuff):
'''Function that reverses the order of elements in a list'''
i = 0
n = len(stuff)-1
while i<n:
temp = stuff[i]
stuff[i] = stuff[n]
stuff[n] = temp
i+=1
n-=1
#test
stuff = [1,2,3,4]
reverse_list(stuff)
print(list) #Output [4,3,2,1]
使用更好的名称,以及您可能会更好地理解的印刷品
def reverse_list(stuff):
begin = 0
end = len(stuff) - 1
while begin < end:
temp = stuff[begin]
stuff[begin] = stuff[end]
stuff[end] = temp
begin += 1
end -= 1
print(stuff)
对于输入[1, 2, 3, 4, 5, 6, 7, 8, 9]
,您会看到
[1, 2, 3, 4, 5, 6, 7, 8, 9]
[9, 2, 3, 4, 5, 6, 7, 8, 1] # swap 1 and 9
[9, 8, 3, 4, 5, 6, 7, 2, 1] # swap 2 and 8
[9, 8, 7, 4, 5, 6, 3, 2, 1] # swap 3 and 7
[9, 8, 7, 6, 5, 4, 3, 2, 1] # swap 4 and 6
方法是,获得两个索引
begin
end
并且每次交换时都使用第三个变量temp
,然后用2乘2交换全部,直到到达中间为止