翻轉(reverse)字符串(string)的所有方法

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

方法如下

5種方法的比較:

1. 簡單的步長爲-1, 即字符串的翻轉(常用);

2. 交換前後字母的位置;

3. 遞歸的方式, 每次輸出一個字符;

4. 雙端隊列, 使用extendleft()函數;

5. 使用for循環, 從左至右輸出;


代碼:

[python] view plain copy
  1. # -*- coding: utf-8 -*-  
  2.   
  3. #eclipse pydev, python 3.3  
  4. #by C.L.Wang   
  5. #time: 2014. 4. 11  
  6.   
  7. string = 'abcdef'  
  8.   
  9. def string_reverse1(string):  
  10.     return string[::-1]  
  11.   
  12. def string_reverse2(string):  
  13.     t = list(string)  
  14.     l = len(t)  
  15.     for i,j in zip(range(l-10, -1), range(l//2)):  
  16.         t[i], t[j] = t[j], t[i]  
  17.     return "".join(t)  
  18.   
  19. def string_reverse3(string):  
  20.     if len(string) <= 1:  
  21.         return string  
  22.     return string_reverse3(string[1:]) + string[0]  
  23.   
  24. from collections import deque  
  25. def string_reverse4(string):  
  26.     d = deque()  
  27.     d.extendleft(string)  
  28.     return ''.join(d)  
  29.   
  30. def string_reverse5(string):  
  31.     #return ''.join(string[len(string) - i] for i in range(1, len(string)+1))  
  32.     return ''.join(string[i] for i in range(len(string)-1, -1, -1))  
  33.   
  34. print(string_reverse1(string))  
  35. print(string_reverse2(string))  
  36. print(string_reverse3(string))  
  37. print(string_reverse4(string))  
  38. print(string_reverse5(string))  

輸出:

[plain] view plain copy
  1. fedcba  
  2. fedcba  
  3. fedcba  
  4. fedcba  
  5. fedcba  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章