LeetCode筆記:14. Longest Common Prefix

問(wèn)題

Write a function to find the longest common prefix string amongst an array of strings.

大意:

寫一個(gè)函數(shù)來(lái)尋找一個(gè)數(shù)組的字符串中最長(zhǎng)的相同前綴理张。

思路:

題目描述很簡(jiǎn)單只有一句話冈欢,導(dǎo)致我理解錯(cuò)了,以為是找到存在的任意兩個(gè)字符串最長(zhǎng)的相同前綴犀勒,還寫了一份代碼出來(lái),自己測(cè)試的時(shí)候發(fā)現(xiàn)題目想要的結(jié)果不符合才發(fā)現(xiàn)侠仇,其實(shí)是找整個(gè)數(shù)組的字符串都有的相同的最長(zhǎng)前綴磕秤,這就方便多了。

我采用從第一個(gè)字符串的前頭開始一個(gè)一個(gè)地增加前綴長(zhǎng)度來(lái)判斷后面所有的字符串是否有同樣的前綴臭笆,然后返回結(jié)果叙淌。

在這個(gè)過(guò)程中有很多特殊情況要注意秤掌,比如如果數(shù)組長(zhǎng)度為0,直接返回空字符串鹰霍;如果只有一個(gè)字符串闻鉴,直接返回該字符串;如果存在某個(gè)字符串(包括第一個(gè))就是“”這樣的空字符串茂洒,直接返回“”孟岛;每次增加前綴長(zhǎng)度的時(shí)候要判斷第一個(gè)字符串是否夠長(zhǎng),不夠了就直接返回當(dāng)前結(jié)果获黔;只有當(dāng)所有后面的字符串都存在前綴時(shí)才可以認(rèn)為是相同的蚀苛,只要有一個(gè)不相同就可以直接返回之前已經(jīng)記錄的前綴了等等。

代碼(Java):

public class Solution {
    public String longestCommonPrefix(String[] strs) {
        if (strs.length == 0) return "";
        else if (strs.length == 1) return strs[0];
        
        int end = 1;
        String result = "";
        String firstStr = strs[0];
        if (firstStr.length() == 0) return "";
        else {
            String sub;
            while (end <= firstStr.length()) {
                sub = firstStr.substring(0, end);
                for (int i = 1; i < strs.length; i++) {
                    String nowStr = strs[i];
                    if (nowStr.length() == 0) return "";
                    else {
                        if (nowStr.startsWith(sub, 0)) {
                            if (i == strs.length-1) {
                                result = sub;
                                end ++;
                            }
                        } else return result;
                    }
                }
            }
        }
        
        return result;
    }
}

他山之石:

public class Solution {
    public String longestCommonPrefix(String[] strs) {
        if (strs.length == 0) return "";
        String pre = strs[0];
        for (int i = 1; i < strs.length; i++)
            while(strs[i].indexOf(pre) != 0) {
                pre = pre.substring(0,pre.length()-1);
                if (pre.length() == 0) return "";
            }
        return pre;
    }
}

這個(gè)做法是先用整個(gè)第一個(gè)字符串來(lái)當(dāng)做前綴去判斷每個(gè)字符串是否擁有該前綴玷氏,沒(méi)有就將這個(gè)判斷的前綴末尾字符去掉再比較堵未,直到當(dāng)前判斷的字符串有這個(gè)前綴了,才去判斷下一個(gè)字符串有沒(méi)有盏触,執(zhí)行同樣的操作渗蟹。當(dāng)任何時(shí)候前綴長(zhǎng)度減少到0了,也可以直接返回了赞辩。這個(gè)做法會(huì)快一點(diǎn)雌芽,而且免去了很多特殊情況的判斷,代碼很簡(jiǎn)潔辨嗽。

合集:https://github.com/Cloudox/LeetCode-Record


查看作者首頁(yè)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末世落,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子糟需,更是在濱河造成了極大的恐慌屉佳,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洲押,死亡現(xiàn)場(chǎng)離奇詭異武花,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)杈帐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門体箕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人挑童,你說(shuō)我怎么就攤上這事累铅。” “怎么了站叼?”我有些...
    開封第一講書人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵娃兽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我大年,道長(zhǎng)换薄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任翔试,我火速辦了婚禮轻要,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘垦缅。我一直安慰自己冲泥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開白布壁涎。 她就那樣靜靜地躺著凡恍,像睡著了一般。 火紅的嫁衣襯著肌膚如雪怔球。 梳的紋絲不亂的頭發(fā)上嚼酝,一...
    開封第一講書人閱讀 51,182評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音竟坛,去河邊找鬼闽巩。 笑死,一個(gè)胖子當(dāng)著我的面吹牛担汤,可吹牛的內(nèi)容都是我干的涎跨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼崭歧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼隅很!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起率碾,我...
    開封第一講書人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤叔营,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后播掷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體审编,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年歧匈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了垒酬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡件炉,死狀恐怖勘究,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斟冕,我是刑警寧澤口糕,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站磕蛇,受9級(jí)特大地震影響景描,放射性物質(zhì)發(fā)生泄漏十办。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一超棺、第九天 我趴在偏房一處隱蔽的房頂上張望向族。 院中可真熱鬧,春花似錦棠绘、人聲如沸件相。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)夜矗。三九已至,卻和暖如春让虐,著一層夾襖步出監(jiān)牢的瞬間紊撕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工澄干, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逛揩,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓麸俘,卻偏偏與公主長(zhǎng)得像辩稽,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子从媚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

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

  • 第5章 引用類型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,233評(píng)論 0 4
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理逞泄,服務(wù)發(fā)現(xiàn),斷路器拜效,智...
    卡卡羅2017閱讀 134,652評(píng)論 18 139
  • 連日來(lái)喷众,冬雨連綿,周末迎來(lái)了難得一見的艷陽(yáng)紧憾,手機(jī)卻無(wú)奈的再次接受被刷機(jī)到千,重獲新生的那一刻,長(zhǎng)嘆一氣赴穗,內(nèi)心油然...
    Jennyxu閱讀 202評(píng)論 0 1
  • 又 又再次回到原點(diǎn) 我們始終沒(méi)有找到一起前行的方向 回 回不到?jīng)]有你的過(guò)去 我要怎么樣才能走出這樣的牢籠 我 不看...
    巴黎草莓閱讀 209評(píng)論 0 0
  • today is a sunny day and the air you touch is not so clea...
    sen伊_閱讀 291評(píng)論 1 0