LeetCode算法題-Reverse Words in a String III(Java實現(xiàn))

這是悅樂書的第259次更新饿这,第272篇原創(chuàng)

01 看題和準(zhǔn)備

今天介紹的是LeetCode算法題中Easy級別的第126題(順位題號是557)眠寿。給定一個字符串,您需要反轉(zhuǎn)句子中每個單詞中的字符順序,同時仍保留空格和初始單詞順序贝奇。例如:

輸入:“Let's take LeetCode contest”
輸出:“s'teL ekat edoCteeL tsetnoc”

注意:在字符串中航棱,每個單詞由單個空格分隔睡雇,并且字符串中不會有任何額外的空格。

本次解題使用的開發(fā)工具是eclipse饮醇,jdk使用的版本是1.8它抱,環(huán)境是win7 64位系統(tǒng),使用Java語言編寫和測試朴艰。

02 第一種解法

將s按照空格拆分為字符串?dāng)?shù)組观蓄,然后對數(shù)組中的每一個元素做翻轉(zhuǎn),再以空格拼接祠墅,作為結(jié)果返回侮穿。

public String reverseWords(String s) {
    String[] arr = s.split(" ");
    StringBuilder result = new StringBuilder();
    for (int i=0; i<arr.length; i++) {
        String ss = arr[i];
        StringBuilder sb = new StringBuilder(ss);
        sb.reverse();
        arr[i] = sb.toString();
        if (i == arr.length-1) {
            result.append(arr[i]);
        } else {
            result.append(arr[i]+" ");
        }
    }
    return result.toString();
}


03 第二種解法

對于第一種解法我們還可以再優(yōu)化下。

public String reverseWords2(String s) {
    String[] arr = s.split(" ");
    StringBuilder result = new StringBuilder();
    for (String ss : arr) {
        result.append(new StringBuilder(ss).reverse().toString()+" ");
    }
    return result.toString().trim();
}


04 第三種解法

我們也可以直接在字符串內(nèi)部進行操作毁嗦。將以空格分割開的單個單詞為一個對象亲茅,對其中的字符進行互換。先將s轉(zhuǎn)為字符數(shù)組狗准,如果當(dāng)前字符不為空格克锣,索引就繼續(xù)向后移動,直到遇到空格為止腔长,此時我們獲取了第一個單詞組成的字符的起始索引袭祟,再使用一次循環(huán),將其字符進行反轉(zhuǎn)捞附,然后將索引還原榕酒。最后將字符數(shù)組轉(zhuǎn)為字符串返回即可胚膊。

public String reverseWords3(String s) {
    char[] arr = s.toCharArray();
    for (int i=0; i<arr.length; i++) {
        if (arr[i] != ' ') {
            int j = i;
            while (i<arr.length && arr[i] != ' ') {
                i++;
            }
            i--;
            int index = i;
            while (j < i) {
                char temp = arr[j];
                arr[j] = arr[i];
                arr[i] = temp;
                j++;
                i--;
            }
            i = index;
        }
    }
    return new String(arr);
}


05 小結(jié)

算法專題目前已日更超過三個月,算法題文章126+篇想鹰,公眾號對話框回復(fù)【數(shù)據(jù)結(jié)構(gòu)與算法】紊婉、【算法】、【數(shù)據(jù)結(jié)構(gòu)】中的任一關(guān)鍵詞辑舷,獲取系列文章合集喻犁。

以上就是全部內(nèi)容,如果大家有什么好的解法思路何缓、建議或者其他問題肢础,可以下方留言交流,點贊碌廓、留言传轰、轉(zhuǎn)發(fā)就是對我最大的回報和支持!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谷婆,一起剝皮案震驚了整個濱河市慨蛙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌纪挎,老刑警劉巖期贫,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異异袄,居然都是意外死亡通砍,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門烤蜕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來封孙,“玉大人,你說我怎么就攤上這事讽营』⒓桑” “怎么了?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵斑匪,是天一觀的道長呐籽。 經(jīng)常有香客問我,道長蚀瘸,這世上最難降的妖魔是什么狡蝶? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮贮勃,結(jié)果婚禮上贪惹,老公的妹妹穿的比我還像新娘。我一直安慰自己寂嘉,他們只是感情好奏瞬,可當(dāng)我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布枫绅。 她就那樣靜靜地躺著,像睡著了一般硼端。 火紅的嫁衣襯著肌膚如雪并淋。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天珍昨,我揣著相機與錄音县耽,去河邊找鬼。 笑死镣典,一個胖子當(dāng)著我的面吹牛兔毙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播兄春,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼澎剥,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赶舆?” 一聲冷哼從身側(cè)響起哑姚,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎涌乳,沒想到半個月后蜻懦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體甜癞,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡夕晓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了悠咱。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒸辆。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖析既,靈堂內(nèi)的尸體忽然破棺而出躬贡,到底是詐尸還是另有隱情,我是刑警寧澤眼坏,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布拂玻,位于F島的核電站,受9級特大地震影響宰译,放射性物質(zhì)發(fā)生泄漏檐蚜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一沿侈、第九天 我趴在偏房一處隱蔽的房頂上張望闯第。 院中可真熱鬧,春花似錦缀拭、人聲如沸咳短。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽咙好。三九已至篡腌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間勾效,已是汗流浹背哀蘑。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留葵第,地道東北人绘迁。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像卒密,于是被迫代替她去往敵國和親缀台。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容