每天一題LeetCode【第5天】

T5. Longest Palindromic Substring 【Medium

題目

給出一個(gè) string 串 s篓跛,找到里面最長(zhǎng)的回文串颖杏。你可以假設(shè) s 最長(zhǎng)的長(zhǎng)度是 1000奶赠。

回文串:一個(gè)正讀和反讀都一樣的字符串

示例1:

輸入: "babad"

輸出: "bab"

提示: "aba" 也是一個(gè)正確的解答.

示例2:

輸入: "cbbd"

輸出: "bb"

思路

主要思路:

回文串分成奇數(shù)和偶數(shù)兩種捎迫,通過(guò)從中心向外擴(kuò)散來(lái)找對(duì)應(yīng)的串武鲁。然后循環(huán)從左到右更換中心點(diǎn)灭翔。

示例:

'|'對(duì)應(yīng)的是指向的標(biāo)號(hào)

奇數(shù)串  babaacd   babaacd   babaacd    得到串a(chǎn)ba
         |        | |      |   | 
偶數(shù)串  babaacd   babaacd              得到串a(chǎn)a
          ||       |  |   

具體可以看下面的代碼以及注釋

代碼

代碼取自 Top Solution嵌言,稍作注釋

public class Solution {
//lo表示回文字符串首字符序號(hào)嗅回,macLen表示回文子串的長(zhǎng)度
private int lo, maxLen;

public String longestPalindrome(String s) {
    //得到字符串長(zhǎng)度
    int len = s.length();
    //若長(zhǎng)度小于2,則就是回文摧茴,直接返回
    if (len < 2)
        return s;
    //用for循環(huán)一個(gè)個(gè)試過(guò)去
    for (int i = 0; i < len-1; i++) {
       //當(dāng)回文串是奇數(shù)的時(shí)候
        extendPalindrome(s, i, i);
        //當(dāng)回文串是偶數(shù)的時(shí)候 
        extendPalindrome(s, i, i+1);
    }
    //返回最長(zhǎng)回文串
    return s.substring(lo, lo + maxLen);
}
//從中間往外擴(kuò)散然后得到回文串
private void extendPalindrome(String s, int j, int k) {
    while (j >= 0 && k < s.length() && s.charAt(j) == s.charAt(k)) {
        //通過(guò)j--,k++向外擴(kuò)散
        j--;
        k++;
    }
    //當(dāng)找到比較長(zhǎng)的串時(shí)保存串初始符號(hào)位置以及長(zhǎng)度
    if (maxLen < k - j - 1) {
        lo = j + 1;
        maxLen = k - j - 1;
    }
}}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末绵载,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子苛白,更是在濱河造成了極大的恐慌娃豹,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件购裙,死亡現(xiàn)場(chǎng)離奇詭異懂版,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)躏率,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門躯畴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人薇芝,你說(shuō)我怎么就攤上這事蓬抄。” “怎么了夯到?”我有些...
    開(kāi)封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵嚷缭,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我黄娘,道長(zhǎng)峭状,這世上最難降的妖魔是什么克滴? 我笑而不...
    開(kāi)封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮优床,結(jié)果婚禮上劝赔,老公的妹妹穿的比我還像新娘。我一直安慰自己胆敞,他們只是感情好着帽,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著移层,像睡著了一般仍翰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上观话,一...
    開(kāi)封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天予借,我揣著相機(jī)與錄音,去河邊找鬼频蛔。 笑死灵迫,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的晦溪。 我是一名探鬼主播瀑粥,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼三圆!你這毒婦竟也來(lái)了狞换?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤舟肉,失蹤者是張志新(化名)和其女友劉穎修噪,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體度气,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡割按,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年膨报,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了磷籍。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡现柠,死狀恐怖院领,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情够吩,我是刑警寧澤比然,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站周循,受9級(jí)特大地震影響强法,放射性物質(zhì)發(fā)生泄漏万俗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一饮怯、第九天 我趴在偏房一處隱蔽的房頂上張望闰歪。 院中可真熱鬧,春花似錦蓖墅、人聲如沸库倘。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)教翩。三九已至,卻和暖如春贪壳,著一層夾襖步出監(jiān)牢的瞬間饱亿,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工闰靴, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留路捧,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓传黄,卻偏偏與公主長(zhǎng)得像杰扫,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子膘掰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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