劍指 Offer 58 翻轉字串

2021-10-10 06:07:52 字數 1413 閱讀 2199

輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。為簡單起見,標點符號和普通字母一樣處理。例如輸入字串"i am a student. 「,則輸出"student. a am i」。

示例 1:

輸入: 「the sky is blue」

輸出: 「blue is sky the」

示例 2:

輸入: " hello world! "

輸出: 「world! hello」

解釋: 輸入字串可以在前面或者後面包含多餘的空格,但是反轉後的字元不能包括。

示例 3:

輸入: 「a good example」

輸出: 「example good a」

解釋: 如果兩個單詞間有多餘的空格,將反轉後單詞間的空格減少到只含乙個。

說明:

方法一:雙指標法。

兩個指標都指向最後,左指標向前移動,一旦碰到空格就停止,並把左右指標之間的字串放入sb。然後左指標繼續向前移動,直到沒有空格,再把右指標和左指標重合,重複之前的過程。

細節:

class

solution

if(res.

length()

>0)

res.

(s.substring

(left+

1,right+1)

);while

(left>=

0&& s.

charat

(left)

==' '

) right=left;

}return res.

tostring()

;}}

方法二:採用分割的方法,然後倒序加入sb

class

solution

return sb.

tostring()

.trim()

;}}

字串的左旋轉操作是把字串前面的若干個字元轉移到字串的尾部。請定義乙個函式實現字串左旋轉操作的功能。比如,輸入字串"abcdefg"和數字2,該函式將返回左旋轉兩位得到的結果"cdefgab"。

示例 1:

輸入: s = 「abcdefg」, k = 2

輸出: 「cdefgab」

示例 2:

輸入: s = 「lrloseumgh」, k = 6

輸出: 「umghlrlose」

class

solution

}

劍指offer58 翻轉字串

題目1 翻轉單詞順序 劍指offer58 翻轉字串 題目1 翻轉單詞順序 方法1 呼叫python內部split函式和切片 def reversesentence s str s.split return join str 1 s i am a student.reversesentence s 方...

劍指 Offer 58 翻轉單詞順序 左旋轉字串

輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。為簡單起見,標點符號和普通字母一樣處理。例如輸入字串 i am a student.則輸出 student.a am i 輸入 the sky is blue 輸出 blue is sky the 輸入 hello world 輸出 w...

劍指offer 面試題58 翻轉字串

牛客最近來了乙個新員工fish,每天早晨總是會拿著一本英文雜誌,寫些句子在本子上。同事cat對fish寫的內容頗感興趣,有一天他向fish借來翻看,但卻讀不懂它的意思。例如,student.a am i 後來才意識到,這傢伙原來把句子單詞的順序翻轉了,正確的句子應該是 i am a student....