快速掌握Python数组的逆序输出几种方法

liftword1周前 (05-28)技术文章8

在 Python 中,可以通过多种方法实现数组的逆序输出。

我用以下是几种常见的方法来讲讲,更多的方法方式就考自己摸索、探究。

方式1:最容易想到的是使用切片

通过 [::-1] 切片语法直接逆序列表:

numarr = [1, 2, 3, 4, 5]
new_numarr = arr[::-1]
print(new_numarr) # 输出 [5, 4, 3, 2, 1]



特点:不会修改原列表,生成一个新列表。

方法 2:使用 reverse() 方法

直接调用列表的 reverse() 方法逆序原列表:

numarr.reverse()
print(arr) # 输出 [5, 4, 3, 2, 1]



特点:直接修改原列表,返回 None。

方法 3:使用 reversed() 函数

通过内置函数 reversed() 生成逆序迭代器,再转换为列表:

reversed_numarr = list(reversed(numarr))
print(reversed_numarr) # 输出 [5, 4, 3, 2, 1]


这里输出了顺的,其实第五行已经是逆序的,再逆序下 就和初始的一样了。应该吧第五行注释掉



特点:不修改原列表,生成新列表。

方法4:不用内置函数,用前后交换或者把交换的方式自定义成函数。

numarr= [1,2,3,4,5]
N = len(numarr)
print (f'初始的数组{numarr}')
for i in range(len(numarr) // 2):
       numarr[i],numarr[N - i - 1] =numarr[N - i - 1],numarr[i]
print (f'交换排序的数组的数组{numarr}')

#方法5,定义一个交互函数
def arr_by_swap(numarr):
    reversed_arr =numarr.copy()  # 避免修改原数组
    n = len(reversed_arr)
    for i in range(n // 2):
        reversed_arr[i], reversed_arr[n-(i+1)] = reversed_arr[n-(i+1)], reversed_arr[i]
    return reversed_arr
arrnew = [1, 2, 3, 4, 5]
reversed_arr = arr_by_swap(arrnew)
print(f'检查原数据{arrnew}')       # 输出 [1, 2, 3, 4, 5](原数组是否修改打印出来对照)
print(reversed_arr)   # 输出 [5, 4, 3, 2, 1]


自己手动交换方式来,比起内置函数肯定要麻烦很多的,如果你刚开始接触或刚入门的话,建议还是多使用原始的方式,分析思路,然后设计代码,反复调试,很多道理就弄的清清楚楚,内置函数内部实现也是一样的,很多情况也确实需要你去重构,每个地方的需求可能发生一点变化。

相关文章

Python算法:4.寻找两个正序数组的中位数

题目:寻找两个正序数组的中位数给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。 算法的时间复杂度应该为 O(log(m+n...

在Python中怎么用二分法插入一个新的数到数组列表

接昨天的把一个数插入到有序的数组、列表中,我们今天使用二分法来,就好比一个队分成2个队,因为有序的么,先比较中间的,得到结果,只要比较一个方向的一半就可以了,这样一来是不是减少一半的时间,节约是运行时...

Python实现【分割数组的最大差值】

n = int(input()) nums = list(map(int, input().split())) total_sum = sum(nums) max_diff = 0 left_sum...

Python实现【找出两个整数数组中同时出现的整数】

from collections import defaultdict import sys def solve(): # 读取输入 arr1 = list(map(int, sys...

Python实现分治算法?

分治算法(Divide and Conquer Algorithm)是一种设计算法的策略,它将一个问题分成多个相似的子问题,递归地解决这些子问题,然后将结果合并以得到原问题的解。典型的分治算法包括归并...

【找出两个整数数组中同时出现的整数】Python实现

from collections import Counter def find_common_elements(arr1, arr2): # 统计数组中每个数字的出现次数 coun...