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

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

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

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

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

更多Python视频、源码、资料加群531509025免费获取

方法一:反转列表法

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

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

方法二:循环反向迭代法

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

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

方法三:反向循环迭代法

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

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

方法四:倒序切片法

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

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

方法五:遍历索引法

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

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

方法六:列表弹出法

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

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

方法七:列表解析式法

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

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

方法八:反向遍历索引法

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

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

方法九:累积相加法

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

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

方法十:匿名函数法

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

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

方法十一:列表倒序法

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

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

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

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

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

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

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

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

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

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

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

方法十五:函数递归法

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

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

方法十六:对称交换法

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

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

  • 36
    点赞
  • 106
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值