翻轉句子中單詞的順序

2021-05-23 20:23:16 字數 1176 閱讀 7220

程式設計師面試題精選(07)-翻轉句子中單詞的順序

題目:輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。句子中單詞以空格符隔開。為簡單起見,標點符號和普通字母一樣處理。

例如輸入「i am a student.」,則輸出「student. a am i」。

分析:由於編寫字串相關**能夠反映程式設計師的程式設計能力和程式設計習慣,與字串相關的問題一直是程式設計師筆試、面試題的熱門題目。本題也曾多次受到包括微軟在內的大量公司的青睞。

由於本題需要翻轉句子,我們先顛倒句子中的所有字元。這時,不但翻轉了句子中單詞的順序,而且單詞內字元也被翻轉了。我們再顛倒每個單詞內的字元。由於單詞內的字元被翻轉兩次,因此順序仍然和輸入時的順序保持一致。

還是以上面的輸入為例子。翻轉「i am a student.」中所有字元得到「.tneduts a ma i」,再翻轉每個單詞中字元的順序得到「students. a am i」,正是符合要求的輸出。

參考**:

///// reverse a string between two pointers

// input: pbegin - the begin pointer in a string

//        pend   - the end pointer in a string

///void reverse(char *pbegin, char *pend)

}///

// reverse the word order in a sentence, but maintain the character

// order inside a word

// input: pdata - the sentence to be reversed

///char* reversesentence(char *pdata)

// a word is between with pbegin and pend, reverse it

else if(*pend == ' ' || *pend == '/0')  //以空格符號' '為標誌,乙個單詞乙個單詞的翻轉。

else

}return pdata;

} 主要思路是,先翻轉整個句子,將所有的單詞均翻轉過來,由於是連續將每個字元均翻轉的,因此,此時不僅翻轉了句子,每個單詞的字母也是翻轉的。而後,以空格符 『 』為標誌,逐個翻轉每個單詞中的字母。

翻轉句子中單詞的順序

題目 輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。句子中單詞以空格符隔開。為簡單起見,標點符號和普通字母一樣處理。例如輸入 i am a student.則輸出 student.a am i 分析 由於編寫字串相關 能夠反映程式設計師的程式設計能力和程式設計習慣,與字串相關的問題...

翻轉句子中單詞的順序

翻轉句子中單詞的順序。題目 輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變。句子中單詞以空格符隔開。為簡單起見,標點符號和普通字母一樣處理。例如輸入 i am a student.則輸出 student.a am i 第乙個想法是借助棧實現,每解析乙個單詞壓棧,解析完依次出棧,要求額...

翻轉句子中單詞的順序

題目 輸入乙個英文句子,翻轉句子中單詞的順序,但單詞內字元的順序不變.句子中單詞以空格符隔開.為簡單起見,標點符號和普通字元一樣處理.例子 輸入 i am a student.輸出 student.a am i 實現 include include include define len 1000 i...