前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试官让用 5 种 python 方法实现字符串反转 ?对不起我有16种……

面试官让用 5 种 python 方法实现字符串反转 ?对不起我有16种……

作者头像
小小詹同学
发布2019-11-12 22:34:43
1.3K0
发布2019-11-12 22:34:43
举报
文章被收录于专栏:小詹同学小詹同学

关键词:Python字符串翻转;面试题

最近身边有个朋友,因为经受不住年薪30W+的诱惑,立志转行成为一名程序员。在自学编程一个月以后,假装自己是学生哥,信心满满地和应届毕业生一起参加了校招。然而,进行了十几次面试,统统折戟沉沙。

这哥们儿面试失意,就来找我诉苦:“面试题目太变态了。比如有家公司,让我用五种编程方法实现字符串反转,整个面试我都在懵逼中度过的!”

啧啧~这明显是基础不够扎实呀!区区五种方法,那可是信手拈来!下面就开始我的表演!~

方法一:反转列表法

a = 'abcdef' b = list(a) b.reverse() b = ''.join(b) print(b)

Python中,列表可以进行反转,我们只要把字符串转换成列表,使用reverse()方法,进行反转,然后再使用字符串的join()方法遍历列表,合并成一个字符串。

方法二:循环反向迭代法

a = 'abcdef' b = '' for i in a: b = i + b print(b)

字符串属于序列的一种,我们可以使用for循环遍历字符串,然后,不断反向赋值给变量b,最后输出变量b,就完成了字符串反转。

方法三:反向循环迭代法

a = 'abcdef' b = '' for i in a[::-1]: #b = b + i b += i print(b)

字符串本身就可以进行切片,当然也可以设置步长为-1,进行倒序。然后,再进行遍历,迭代变量b,也可以达到反转效果,逻辑和方法二相同。

方法四:倒序切片法

a = 'abcdef' b = a[::-1] print(b)

方法二和方法三的终极版本,直接反转,一步到位。

方法五:遍历索引法

a = 'abcdef' b = '' for i in range(1,len(a)+1): b = b + a[-i] print(b)

字符串作为序列,可以进行索引,我们先遍历索引数字,然后倒序提取字母,然后合并成字符串。

方法六:列表弹出法

a = 'abcdef' a = list(a) b = '' while len(a) > 0: b = b + a.pop() print(b)

列表有一种弹出的方法pop(),弹出其中某个元素,默认为最后一个元素。我们设置变量b,然后不断弹出字符串的最后一个字符,加入变量b中,最终使得字符串反转。

方法七:列表解析式法

a = 'abcdef' b = ''.join(i for i in a[::-1]) print(b)

方法三的简便写法,使用列表解析式,简化代码书写。最后同样通过join()方法,反转合并字符串。

方法八:反向遍历索引法

a = 'abcdef' b = ''.join(i for i in a[::-1]) print(b)

range()函数有三个参数:start,end,step,且左闭右开,我们从最后一个索引开始,最开始的索引结束,倒序遍历索引,然后反向提取字符串,最后合并。是方法五的逆向思维。

方法九:累积相加法

a = 'abcdef' from functools import reduce def f(x,y): return y + x b = reduce(f,a) print(b)

使用python中的reduce()函数。先创建一个字符串倒序相加函数和字符串,一起传入reduce函数中,运行,就可以进行字符串倒序累积相加,最后反转字符串。

方法十:匿名函数法

a = 'abcdef' b = reduce(lambda x,y:y+x,a) print(b)

方法九的进阶版,使用lambda匿名函数创建字符串倒序相加函数,然后进行累积,得到字符串反转结果。

方法十一:列表倒序法

a = 'abcdef' a = list(a) a.sort(reverse=True) b = ''.join(a) print(b)

用列表的sort(reverse=True)方法,倒序排列,不过,这一方法有个弊端,它并不是按字符串的顺序进行升序或降序排列,而是按英语26个字母进行排序,所以,如果字符串不是按从小到大排列,那么运行后,排序会是错误的。

方法十二:双向队列排序法

a = 'abcdef' import collections b = collections.deque() for i in a: b.appendleft(i) b = ''.join(b) print(b)

使用双向队列进行操作。解释下双向队列,这是一个数据结构,但可以方便的向序列的两边进行添加,删除元素。我们遍历字符串,向左添加入双向队列中,最后使用join()方法合并,使字符串反转。

方法十三:双向队列反转法:

a = 'abcdef' b = collections.deque() b.extend(list(a)) b.reverse() b = ''.join(b) print(b)

同样使用双向队列,把字符串转换成列表添加入队列中,然后整个进行反转,最后合并导出。

方法十四:一维数组索引法

a = 'abcdef' import pandas as pd b = pd.Series(list(a)) b = ''.join(b[::-1]) print(b)

使用pandas的一维数组结构,对其倒序遍历,反转字符串。

方法十五:函数递归法

a = 'abcdef' def f(a): if len(a) <= 1: return a return a[-1] + f(a[:-1]) b = f(a) print(b)

使用递归的思想,建立函数,倒序添加字符串,直到字符串长度小于等于1以后停止。

方法十六:对称交换法

a = 'abcdef' def f(a): a = list(a) if len(a) <=1: return a i = 0 length = len(a) while i < length/2: a[i],a[length - 1 - i] = a[length - 1 - i],a[i] i += 1 return ''.join(a) b = f(a) print(b)

这是最为销魂的一个方法~大体思路是遍历字符串前一半的元素,然后和后一半对称的那个位置的元素进行交换,以达到字符串反转。过程非常讲究逻辑~

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-12-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 小詹学Python 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档