<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
一道題目是實現一個反轉字串的函數,具體如下:
編寫一個函數,其作用是將輸入的字串反轉過來。輸入字串以字元陣列 char[] 的形式給出。
不要給另外的陣列分配額外的空間,你必須原地修改輸入陣列、使用 O(1) 的額外空間解決這一問題。
我們可以假設陣列中的所有字元都是 ASCII 碼錶中的可列印字元。
範例 1:
輸入:["h","e","l","l","o"]
輸出:["o","l","l","e","h"]
範例 2:
輸入:["H","a","n","n","a","h"]
輸出:["h","a","n","n","a","H"]
自己動手操作了一下,大概有如下幾種方式
如果不考慮題目中所說的“原地修改輸入陣列”,可以藉助一箇中間列表來實現
從列表的尾部向前遍歷,可以通過如下2種方式定義索引:
def reverseString_1(self, s): """ 思路:藉助一箇中間變數temp,然後從s的尾部提取,把元素追加到temp中 :param s: :return: """ temp = [] for i in range(len(s)): temp.append(s[len(s)-1-i]) return temp def reverseString_2(self, s): """ 思路:和方法4一樣,不過換個實現方式(和第8題方法2用到的倒序迴圈一樣) :param s: :return: """ temp = [] for i in range(len(s)-1, -1, -1): # range中的表示索引範圍,len(s)-1表示遍歷的第一個元素(也就是從最後一個元素開始遍歷); # 第一個-1表示最後一個位置,不過由於遍歷範圍右邊不閉合,所以這裡其實最終遍歷的是第一個元素; # 第二個-1表示步長,每次-1,即從後往前遍歷 temp.append(s[i]) return temp
思考一下:
反轉字串其實可以轉換為“首尾元素串互換”,如:第1位和倒數第1位互換、第2位和倒數第2位互換、第3位和倒數第3位互換
[1,2,3,4,5,6]
[6,5,4,3,2,1]
這樣的話,可以定義2個指標,一個從首位遍歷往後遍歷,一個從末尾往前遍歷;
然後每次遍歷都交換2個位置的元素,一直遍歷到中間元素;
def reverseString(self, s): """ :type s: List[str] :rtype: None Do not return anything, modify s in-place instead. """ i = 0 # 第一個指標,從首部遍歷 j = len(s) - 1 # 第二個指標,從尾部遍歷 while j > i: # 如果j>i就一直迴圈,直到2個指標相遇 s[i], s[j] = s[j], s[i] # 交換2個位置的元素 i += 1 j -= 1 return s
這個方法比較繞,而且在提交時,由於超時導致並未通過(系統給出的陣列太長導致),不過自己測試時給了幾個陣列,也能正常倒序輸出
思路如下:既然是倒序輸出,可以把第1個和第2個元素互換,然後第2個和第3個互換…直到把第1個元素挪到了最後的位置;
但是此時還未結束,這只是把第1個元素挪到了最後,還需要重複上述步驟,再把原先的第2個元素(現在的第1個元素)挪到倒數第2個位置(注意:此時的最後一個元素不能動)
按照上述步驟,把所有元素都挪動一遍,就完成了
def reverseString(self, s): """ 思路: :type s: List[str] :rtype: None Do not return anything, modify s in-place instead. """ n = 0 while n < len(s): i = 0 for j in range(1, len(s)-n): s[i], s[j] = s[j], s[i] i += 1 n += 1 return s
利用切片來實現倒序輸出:
''' 學習中遇到問題沒人解答?小編建立了一個Python學習交流QQ群:857662006 尋找有志同道合的小夥伴,互幫互助,群裡還有不錯的視訊學習教學和PDF電子書! ''' def reverseString(self, s): """ 思路:切片 s[::-1]表示反轉s中的元素 s[:]表示陣列中所有子模組 s[:]=s[::-1]表示將原陣列反轉後賦值給s中每一個對應的位置 s=s[::-1]表示將s反轉後賦值給新的物件s,與題意原地修改不符 :param s: :return: """ s[:] = s[::-1] return s
使用reverse()方法,它會對原列表進行反向排序(注意:reverse只對list有效)
def reverseString_6(self, s): """ :param s: :return: """ s.reverse() return s
不過reverse()方法的原始碼,會發現它其實就是利用的切片,如下:
到此這篇關於Python中五種實現字串反轉的方法的文章就介紹到這了,更多相關python字串反轉內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45