前段時(shí)間看到letcode上的元音字母字符串反轉(zhuǎn)的題目,今天來(lái)研究一下字符串反轉(zhuǎn)的內(nèi)容。主要有三種方法:
1.切片法(最簡(jiǎn)潔的一種)
#切片法def reverse1(): s=input("請(qǐng)輸入需要反轉(zhuǎn)的內(nèi)容:") return s[::-1]reverse1()#運(yùn)行結(jié)果In [23]: def reverse1(): ...: s=input("請(qǐng)輸入需要反轉(zhuǎn)的內(nèi)容:") ...: return s[::-1] ...: ...: reverse1()請(qǐng)輸入需要反轉(zhuǎn)的內(nèi)容:你是一個(gè)小南瓜Out[23]: '瓜南小個(gè)一是你' 參考stackflow上的答案。
原理是:This is extended slice syntax. It works by doing [begin:end:step] - by leaving begin and end off and specifying a step of -1, it reverses a string.
切片介紹:切片操作符中的第一個(gè)數(shù)(冒號(hào)之前)表示切片開始的位置,第二個(gè)數(shù)(冒號(hào)之后)表示切片到哪里結(jié)束,第三個(gè)數(shù)(冒號(hào)之后)表示切片間隔數(shù)。如果不指定第一個(gè)數(shù),Python就從序列首開始。如果沒(méi)有指定第二個(gè)數(shù),則Python會(huì)停止在序列尾。注意,返回的序列從開始位置開始 ,剛好在結(jié)束位置之前結(jié)束。即開始位置是包含在序列切片中的,而結(jié)束位置被排斥在切片外。
這樣,a[1:3]返回從位置1開始,包括位置2,但是停止在位置3的一個(gè)序列切片,因此返回一個(gè)含有兩個(gè)項(xiàng)目的切片。類似地,a[:]返回整個(gè)序列的拷貝。a[::3]返回位置3,位置6,位置9…的序列切片。
也可以用負(fù)數(shù)做切片。負(fù)數(shù)用在從序列尾開始計(jì)算的位置。例如,a[:-1]會(huì)返回除了最后一個(gè)項(xiàng)目外包含所有項(xiàng)目的序列切片,shoplist[::-1]會(huì)返回倒序序列切片。
舉一個(gè)完整例子,讀入用戶輸入并反轉(zhuǎn)字符串,并寫入到文件中
#!/usr/bin/pythonimport sys#打開文件進(jìn)行寫入myfile=open('test.txt','w') while 1: print "input your string /n" #readline會(huì)讀入最后的換行符 line=sys.stdin.readline() #判斷輸入是否為空字符串 if line.strip('/n')=='': break #原輸入字符串合并上反轉(zhuǎn)的字符串 allmessage=line[:-1]+line.strip('/n')[::-1] print allmessage #輸入及轉(zhuǎn)換后的字符串寫入到文件中 myfile.write(allmessage+'/n')#記得關(guān)閉文件操作流myfile.close()用shell bash方法可以如下:
#! /bin/shwhile truedo echo "Pls enter your string" "/n" read my if [ -z $my ]; then break fi remy=$(echo $my | rev) echo $my$remy echo $my$remy >> test.txtdone
2.遞歸
#遞歸反轉(zhuǎn)def reverse2(s): if s=="": return s else: return reverse2(s[1:])+s[0]reverse2("sidfmawsmdisd是當(dāng)面問(wèn)")#運(yùn)行結(jié)果In [24]: def reverse2(s): ...: if s=="": ...: return s ...: else: ...: return reverse2(s[1:])+s[0] ...: ...: reverse2("sidfmawsmdisd是當(dāng)面問(wèn)")Out[24]: '問(wèn)面當(dāng)是dsidmswamfdis' 3.借用列表,使用reverse()方法
Python中自帶reverse()函數(shù),可以處理列表的反轉(zhuǎn),來(lái)看示例:
In [25]: l=['a', 'b', 'c', 'd'] ...: l.reverse() ...: print (l)['d', 'c', 'b', 'a']
reverse()函數(shù)將列表的內(nèi)容進(jìn)行了反轉(zhuǎn),借助這個(gè)特性,可以先將字符串轉(zhuǎn)換成列表,利用reverse()函數(shù)進(jìn)行反轉(zhuǎn)后,再處理成字符串。
#借用列表,使用reverse()方法def reverse3(s): l=list(s) l.reverse() print("".join(l))reverse3("soifmi34pomOsprey,,是")#運(yùn)行結(jié)果In [26]: def reverse3(s): ...: l=list(s) ...: l.reverse() ...: print("".join(l)) ...: ...: reverse3("soifmi34pomOsprey,,是") ...: 是,,yerpsOmop43imfiosPython字符串反轉(zhuǎn)
對(duì)于str類型,python并沒(méi)有reverse函數(shù)。然而,通過(guò)反向步進(jìn)切片,我們可以高效地反轉(zhuǎn)一串字符串。
s = 'abcde' s[::-1]
好吧,只支持英文字符。
以下是SpikeKing的內(nèi)容
原文:http://blog.csdn.net/caroline_wendy/article/details/23438739
Python翻轉(zhuǎn)字符串(reverse string), 一共包含5種方法, 其中第一種最簡(jiǎn)單, 即步長(zhǎng)為-1, 輸出字符串;
方法如下
5種方法的比較:
1. 簡(jiǎn)單的步長(zhǎng)為-1, 即字符串的翻轉(zhuǎn)(常用);
2. 交換前后字母的位置;
3. 遞歸的方式, 每次輸出一個(gè)字符;
4. 雙端隊(duì)列, 使用extendleft()函數(shù);
5. 使用for循環(huán), 從左至右輸出;
代碼:
# -*- coding: utf-8 -*- #eclipse pydev, python 3.3 #by C.L.Wang #time: 2014. 4. 11 string = 'abcdef' def string_reverse1(string): return string[::-1] def string_reverse2(string): t = list(string) l = len(t) for i,j in zip(range(l-1, 0, -1), range(l//2)): t[i], t[j] = t[j], t[i] return "".join(t) def string_reverse3(string): if len(string) <= 1: return string return string_reverse3(string[1:]) + string[0] from collections import deque def string_reverse4(string): d = deque() d.extendleft(string) return ''.join(d) def string_reverse5(string): #return ''.join(string[len(string) - i] for i in range(1, len(string)+1)) return ''.join(string[i] for i in range(len(string)-1, -1, -1)) print(string_reverse1(string)) print(string_reverse2(string)) print(string_reverse3(string)) print(string_reverse4(string)) print(string_reverse5(string))
輸出:
fedcba
fedcba
fedcba
fedcba
fedcba
繼續(xù)補(bǔ)充一個(gè)方法
def reverse(str): alist = list(str) alist.reverse() new_str = ''.join(alist) return new_strprint reverse('vevb.com')經(jīng)測(cè)試輸出完全正確。
Python里面 str[::-1] 使得字符串翻轉(zhuǎn)的原理是什么
我覺(jué)得很多人不理解這個(gè)語(yǔ)法是把倆冒號(hào)看成一個(gè)符號(hào)了,其實(shí)這是兩個(gè)冒號(hào),而不是一個(gè)雙冒號(hào)符
給你一個(gè)例子看看:
>>> a='0123456'
>>> a[1:5]'1234'
返回結(jié)果是1234,能理解么?第一位到第五位切片(初始是0位)
>>> a[1:5:2]'13'
這個(gè)呢?能理解么?1-5位切片,步進(jìn)為2,所以取出來(lái)是‘13'那么問(wèn)題就來(lái)了[::-1]表示的是從頭到尾,步長(zhǎng)為-1,你感受一下。你可以嘗試吧-1改一下,比如[::-2]
這篇文章就介紹到這,希望大家以后多多支持VEVB武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選