劍指 Offer 58 I 翻轉單詞順序

2022-06-10 09:12:10 字數 1194 閱讀 9309

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

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

說明:

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

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

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

去掉字串首位空格(這裡需要考慮的特殊情況:全是空格的情況)

使用雙指標ijij均初始化至字串末尾

i向前移動,直至找到第乙個為空格的字元,此時字串s的在ij之間的子字串即為最後乙個單詞

i繼續向前移動,直至找到下乙個不為空格的字元,令ij均指向此處,重複步驟3,得到倒數第二個、第三個...、第n個單詞

為了方便處理邊界條件,即i == 0的情況,在第3步之前,對輸入的字串去掉首位空格後,在此字串首插入乙個空格。

class solution 

result.erase(result.length() - 1, 1);

return result;

}};

劍指 Offer 58 I 翻轉單詞順序

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

劍指 Offer 58 I 翻轉單詞順序

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

劍指 Offer 58 I 翻轉單詞順序

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