面試題58 I 翻轉單詞順序

2021-10-23 07:02:09 字數 1108 閱讀 4012

題目描述

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

從i開始消除len個字元

//a + b 字串拼接

class

solution}if

(len !=

0) retstr +

= s.

substr(0

,len)

;//第乙個字母前沒有空格,for迴圈裡沒新增上第乙個單詞

else

if(retstr.

size()

>

0) retstr.

erase

(retstr.

size()

-1,1

);//第乙個字母前有空格,for迴圈裡新增上了第乙個單詞

//判斷條件 防止 特殊情況s = " "

return retstr;}}

;

思路2

兩次反轉

第一次,反轉每個單詞

eht yks si eulb

第二次,反轉整個字串

blue is sky the

58 I 翻轉單詞順序

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

劍指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 自...

面試題58 題目一 翻轉單詞順序

面試題58 題目一 翻轉單詞順序 題目 輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。為簡單起見,標點符號和普通字母一樣處理。例如輸入字串 i am a student.則輸出 student.a am i 思路 第一步翻轉句子中所有的字元。比如翻轉 i am a student....