Python中列表和字符串的反转

枫铃3年前 (2021-09-30)Python235

要求:

  • 原列表:[13, 30, 42, 85, 9, 45]

  • 反转后的列表:[45, 9, 85, 42, 30, 13]

  • 原字符串:hello

  • 反转后的字符串:olleh

Python现成的反转功能:

在Python中有专门进行列表反转的函数–reverse()

l = [13, 30, 42, 85, 9, 45]
l.reverse() # [45, 9, 85, 42, 30, 13]

还可以使用切片操作进行列表反转

l = [13, 30, 42, 85, 9, 45]
print(l[::-1]) # [45, 9, 85, 42, 30, 13]

关于字符串的反转,并没有确切的函数对字符串进行反转,但是字符串也可以使用切片进行反转

s = "hello"
print(s[::-1]) # olleh

以上对列表和字符串的反转,都是现成的,使用起来很方便;但是我们也可以自己为列表和字符串手写一个反转函数(仅供参考)

手写列表反转函数:

思路1:

  • 把列表中的值当成转成字典的value,字典的key为递增的数字
  • 通过sorted()对字典key进行降序
  • 依次取出进行降序后字典的value值,放到列表中
  • 得到的就是反转后的列表

代码:

'''
Python学习交流,免费公开课,免费资料,
免费答疑,系统学习加QQ群:579817333 
'''
def reverse_list(n: list) -> list:
    d = dict(zip([i for i in range(len(n))], n))
    return [d[k] for k in sorted(d, reverse=True)]

使用:

l = [13, 30, 42, 85, 9, 45]
print(reverse_list(l)) # [45, 9, 85, 42, 30, 13]

思路2:

  • 把列表通过 enumerate() 返回一个可以枚举的对象,该对象的next()方法将返回一个元组
  • 把返回的元组放到一个新的列表中,通过sorted() 进行列表排序(根据列表中元组元素的第一个元素进行排序,使用降序)
  • 遍历排序后的新列表,取每个元组元素的第二个元素,组成新列表
  • 得到的新列表就是反转后的列表

代码:

def reverse_list(l: list) -> list:
    return [i[1] for i in sorted([v for v in enumerate(l)], reverse=True)]

使用:

l = [13, 30, 42, 85, 9, 45]
print(reverse_list(l)) # [45, 9, 85, 42, 30, 13]

思路3:

  • 取列表最后一位追加到新列表后面
  • 然后通过切片把最后一位之前的数据重新赋值给当前列表
  • 依次重复操作,直至列表为空
  • 得到的新列表就是反转后的

代码:

'''
Python学习交流,免费公开课,免费资料,
免费答疑,系统学习加QQ群:579817333 
'''
def reverse_list(n: list) -> list:
    a = []
    while len(n) > 0:
        a.append(n[-1])
        n = n[:-1]
    return a

使用:

l = [13, 30, 42, 85, 9, 45]
print(reverse_list(l)) # [45, 9, 85, 42, 30, 13]

思路4:

  • 通过切片获取列表下标为 [-i - 1] 的元素
  • 把切片得到的元素添加到新的列表中
  • 依次重复操作,直至循环结束
  • 得到的新列表就是反转后的

代码:

def reverse_list(n: list) -> list:
    return [n[-i - 1] for i in range(len(n))]

使用:

l = [13, 30, 42, 85, 9, 45]
print(reverse_list(l)) # [45, 9, 85, 42, 30, 13]

手写字符串反转函数:

思路1:

  • 通过切片获取字符串最后一位
  • 通过字符串拼接,把最后一位拼接到新的字符串中
  • 然后通过切片把最后一位之前的数据重新赋值给当前字符串
  • 依次重复操作,直至字符串为空
  • 得到的新字符串就是反转后的

代码:

'''
Python学习交流,免费公开课,免费资料,
免费答疑,系统学习加QQ群:579817333 
'''
def reverse_str(s: str) -> str:
    new_s = ''
    while len(s) > 0:
        new_s += (s[-1])
        s = s[0:-1]
    return new_s

使用:

s = "hello"
print(reverse_str(s)) # olleh

思路2:

  • 通过切片获取字符串下标为 [-i - 1] 的元素
  • 通过字符串拼接,把切片得到的元素拼接到新的字符串中
  • 依次重复操作,直至循环结束
  • 得到的新字符串就是反转后的

代码:

def reverse_str(s: str) -> str:
    new_s = ''
    for i in range(len(s)):
        new_s += s[-i - 1]
    return new_s

使用:

s = "hello"
print(reverse_str(s)) # olleh

以上就是关于Python中列表和字符串的反转操作(这才是冰山一角,还有更多的实现方式),实际应用中还是使用列表自带的函数和切片操作进行反转即可,手写的仅供参考使用,写代码嘛,怎么简单易懂怎么来。

相关文章

利用python同步windows和linux文件

写python脚本的初衷,每次在windows编辑完文件后,想同步到linux上去,只能够登录服务器,...

爬虫基本原理

爬虫基本原理 一、爬虫是什么? 百度百科和维基百科对网络爬虫的定义:简单来说爬虫就是抓取目标网站内容的工具,一般是根据定义的行...

Django 函数和方法的区别

函数和方法的区别 1、函数要手动传self,方法不用传 2、如果是一个函数,用类名去调用,如果是一个方法...

Django 知识补漏单例模式

单例模式:(说白了就是)创建一个类的实例。在 Python 中,我们可以用多种方法来实现单例模式&#x...

Django基础知识MTV

Django简介 Django是使用Python编写的一个开源Web框架。可以用它来快速搭建一个高性能的网站。 Django也是一个MVC框架。但是在Dj...

Python mysql 索引原理与慢查询优化

一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。