劍指offer第二版-58.翻轉(zhuǎn)單詞順序

本系列導(dǎo)航:劍指offer(第二版)java實(shí)現(xiàn)導(dǎo)航帖

面試題58:翻轉(zhuǎn)單詞順序

題目要求:
輸入一個(gè)英文句子,翻轉(zhuǎn)單詞順序,單詞內(nèi)字符不翻轉(zhuǎn),標(biāo)點(diǎn)符號(hào)和普通字母一樣處理。例如輸入輸入“I am a student.”,則輸出“student. a am I”。

解題思路:
首先字符串整體翻轉(zhuǎn),得到“.tneduts a ma I”;然后以空格作為分隔符進(jìn)行切分,對(duì)于切分下來的每一部分再進(jìn)行翻轉(zhuǎn),得到“student. a am I”。

package chapter6;

/**
 * Created with IntelliJ IDEA
 * Author: ryder
 * Date  : 2017/8/17
 * Time  : 16:01
 * Description:翻轉(zhuǎn)字符串
 **/
public class P284_ReverseWordsInSentence {
    public static String reverse(String str){
        StringBuilder stringBuilder = new StringBuilder(str);
        reverseSubString(stringBuilder,0,stringBuilder.length()-1);
        int start = 0,end = stringBuilder.indexOf(" ");
        while (start<stringBuilder.length()&&end!=-1){
            reverseSubString(stringBuilder,start,end-1);
            start = end+1;
            end = stringBuilder.indexOf(" ",start);
        }
        if(start<stringBuilder.length())
            reverseSubString(stringBuilder,start,stringBuilder.length()-1);
        return stringBuilder.toString();
    }
    //翻轉(zhuǎn)stringBuilder[start,end]
    public static void reverseSubString(StringBuilder stringBuilder,int start,int end){
        for(int i=start;i<=start+(end-start)/2;i++){
            char temp = stringBuilder.charAt(i);
            stringBuilder.setCharAt(i,stringBuilder.charAt(end-i+start));
            stringBuilder.setCharAt(end-i+start,temp);
        }
    }
    public static void main(String[] args){
        System.out.println(reverse("I am a student."));
    }
}

運(yùn)行結(jié)果

student. a am I
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 劍指 offer 在一個(gè)二維數(shù)組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請(qǐng)完成...
    faremax閱讀 2,328評(píng)論 0 7
  • 題目一:輸入一個(gè)英文句子,翻轉(zhuǎn)句子中單詞的順序,但單詞內(nèi)字符的順序不變。為簡單起見,標(biāo)點(diǎn)符號(hào)和普通字母一樣處理。例...
    qmss閱讀 458評(píng)論 0 0
  • 說明: 本文中出現(xiàn)的所有算法題皆來自??途W(wǎng)-劍指Offer在線編程題,在此只是作為轉(zhuǎn)載和記錄,用于本人學(xué)習(xí)使用,不...
    秋意思寒閱讀 1,218評(píng)論 1 1
  • 劍指offer 最近在??途W(wǎng)上刷劍指offer的題目,現(xiàn)將題目和答案(均測試通過)總結(jié)如下: 第一個(gè)只出現(xiàn)一次的字...
    閆阿佳閱讀 667評(píng)論 0 3
  • Tempo: 一段音樂的速度(拍子的速度)。有兩種方式來指定 Tempo,一種是指定每分鐘 Beat 的數(shù)量,一種...
    諸葛飛閱讀 448評(píng)論 0 0

友情鏈接更多精彩內(nèi)容