国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

簡單談談Python中的反轉字符串問題

2020-02-23 01:41:49
字體:
來源:轉載
供稿:網友

按單詞反轉字符串是一道很常見的面試題。在Python中實現起來非常簡單。

def reverse_string_by_word(s): lst = s.split() # split by blank space by default return ' '.join(lst[::-1])s = 'Power of Love'print reverse_string_by_word(s)# Love of Powers = 'Hello World!'print reverse_string_by_word(s)# World! Hello

上面的實現其實已經能滿足大多數情況,但是并不完美。比如第二個字符串中的感嘆號并沒有被翻轉,而且原字符串中的空格數量也沒有保留。(在上面的例子里其實Hello和World之間不止一個空格)

我們期望的結果應該是這樣子的。

print reverse_string_by_word(s)# Expected: !World Hello

要改進上面的方案還不把問題復雜化,推薦使用re模塊。你可以查閱re.split() 的官方文檔。我們看一下具體例子。

>>> import re>>> s = 'Hello World!'>>> re.split(r'/s+', s) # will discard blank spaces['Hello', 'World!']>>> re.split(r'(/s+)', s) # will keep spaces as a group['Hello', ' ', 'World!']>>> s = '< Welcome to EF.COM! >'>>> re.split(r'/s+', s) # split by spaces['<', 'Welcome', 'to', 'EF.COM!', '>']>>> re.split(r'(/w+)', s) # exactly split by word['< ', 'Welcome', ' ', 'to', ' ', 'EF', '.', 'COM', '! >']>>> re.split(r'(/s+|/w+)', s) # split by space and word['<', ' ', '', 'Welcome', '', ' ', '', 'to', '', ' ', '', 'EF', '.', 'COM', '!', ' ', '>']>>> ''.join(re.split(r'(/s+|/w+)', s)[::-1])'> !COM.EF to Welcome <'>>> ''.join(re.split(r'(/s+)', s)[::-1])'> EF.COM! to Welcome <'>>> ''.join(re.split(r'(/w+)', s)[::-1])'! >COM.EF to Welcome< '

如果你覺得用切片將序列倒序可讀性不高,那么其實也可以這樣寫。

>>> ''.join(reversed(re.split(r'(/s+|/w+)', s)))'> !COM.EF to Welcome <'

一句話搞定,so easy!

Python翻轉字符串(reverse string), 一共包含5種方法, 其中第一種最簡單, 即步長為-1, 輸出字符串;

方法如下

5種方法的比較:

1. 簡單的步長為-1, 即字符串的翻轉(常用);
2. 交換前后字母的位置;
3. 遞歸的方式, 每次輸出一個字符;
4. 雙端隊列, 使用extendleft()函數;
5. 使用for循環, 從左至右輸出;

代碼:

# -*- 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))             
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 顺义区| 鄂州市| 沙坪坝区| 东宁县| 吴江市| 建水县| 承德市| 方城县| 德江县| 宁远县| 浮梁县| 黄山市| 怀仁县| 南宁市| 南澳县| 大城县| 莱芜市| 伊宁市| 三明市| 乌兰县| 台中县| 安国市| 新泰市| 黄梅县| 桃园市| 津南区| 方城县| 宜城市| 安溪县| 牙克石市| 大悟县| 伽师县| 长春市| 南开区| 资中县| 大田县| 东明县| 洛宁县| 临江市| 定州市| 合作市|