58 I 翻轉單詞順序

2021-10-22 07:24:57 字數 1241 閱讀 6945

輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。為簡單起見,標點符號和普通字母一樣處理。例如輸入字串"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」

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

說明:

無空格字元構成乙個單詞。

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

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

/*

迴圈執行:

1. 索引i從右向左搜尋首個空格

2. 新增單詞[i+1,j+1)到res

3. 索引i跳過兩個單詞間的所有空格

4. 執行j=i此時j表示下乙個單詞的尾字元

*/class

solution

//單詞加入結果集和乙個空格 s.substring(i+1,j+1)屬於左閉右開切割字串並返回

res.

(s.substring

(i+1

,j+1)+

" ")

;//i跳過兩個單詞的所有空格找下乙個單詞的尾

while

(i>=

0&&s.

charat

(i)==

' ')

j=i;

}//拼接的結果集尾有空格要去除

return res.

tostring()

.trim()

;}}

時間複雜度:o(n) n為字元春的長度

空間複雜度:o(n)stringbuilder中的字串總長度為n

面試題58 I 翻轉單詞順序

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

劍指offer 雙指標 58 I 翻轉單詞順序

時間複雜度 o n 空間複雜度 o 1 class solution reverse s.begin s.end 去除首尾的空格 int k 0 while k s.size s k k int j s.size 1 while j 0 s j j return s.substr k,j k 1 自...

劍指 Offer 58 I 翻轉單詞順序

題目 leetcode上面這道題與書上有些許不同,leetcode還考慮句子首尾和末尾有空格的情況,以及單詞之間存在多個空格。思路1 class solution return res.tostring trim 思路2 先剔除字串首尾的空格,然後利用split 函式,根據空格劃分,返回乙個stri...