輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。為簡單起見,標點符號和普通字母一樣處理。例如輸入字串"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"
解釋: 如果兩個單詞間有多餘的空格,將反轉後單詞間的空格減少到只含乙個。
說明:
無空格字元構成乙個單詞。
輸入字串可以在前面或者後面包含多餘的空格,但是反轉後的字元不能包括。
如果兩個單詞間有多餘的空格,將反轉後單詞間的空格減少到只含乙個。
去掉字串首位空格(這裡需要考慮的特殊情況:全是空格的情況)
使用雙指標i
和j
,i
和j
均初始化至字串末尾
i
向前移動,直至找到第乙個為空格的字元,此時字串s
的在i
和j
之間的子字串即為最後乙個單詞
i
繼續向前移動,直至找到下乙個不為空格的字元,令i
和j
均指向此處,重複步驟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 ...