使用Python内置函数reversed()python
for i in reversed(arr): pass
reversed返回的是迭代器,因此不用担忧内存问题。数组
使用range()
倒序函数
for i in range(len(arr) - 1, -1, -1): pass
先使用list
自带的reverse()
函数,再用range()
循环3d
arr.reverse() for i in range(len(arr)): pass
由于要先倒序,再循环,因此效率会比较低。code
先使用list
自带的sort()
函数来倒序,再用range()
循环blog
arr.sort(reverse=True) for i in range(len(arr)): pass
由于要先排序,再循环,因此效率会比较低。排序
这里不讨论Python内置函数sorted()
,它的效率比list
自带的sort()
函数要慢。内存
import time arr = [x for x in range(10000000)] arr1 = arr.copy() start = time.process_time() for i in reversed(arr): pass end = time.process_time() print('方法一(reversed):', end - start) start = time.process_time() for i in range(len(arr) - 1, -1, -1): pass end = time.process_time() print('方法二(range倒序):', end - start) start = time.process_time() arr.reverse() for i in range(len(arr)): pass end = time.process_time() print('方法三(先reverse再range):', end - start) start = time.process_time() arr1.sort(reverse=True) for i in range(len(arr1)): pass end = time.process_time() print('方法四(先sort再range):', end - start)
数组长度为一百万时(跑了三次):
class
数组长度为一千万时(跑了两次):
效率
数组长度为一亿时(跑了两次):
效率:方法一 > 方法二 > 方法三 > 方法四 然而并不差多少emmm 但仍是尽可能使用迭代器吧,数据量很大的时候不用迭代器的话有可能会占用过多的内存。