LintCode - 鏈表劃分(普通)

版權(quán)聲明:本文為博主原創(chuàng)文章邻辉,未經(jīng)博主允許不得轉(zhuǎn)載骏啰。

難度:容易
要求:

給定一個(gè)單鏈表和數(shù)值x磅叛,劃分鏈表使得所有小于x的節(jié)點(diǎn)排在大于等于x的節(jié)點(diǎn)之前。你應(yīng)該保留兩部分內(nèi)鏈表節(jié)點(diǎn)原有的相對順序皆辽。
樣例
給定鏈表 1->4->3->2->5->2->null柑蛇,并且 x=3返回** 1->2->2->4->3->5->null**

思路
多指針偏移

/**
     * @param head: The first node of linked list.
     * @param x: an integer
     * @return: a ListNode 
     */
    public ListNode partition(ListNode head, int x) {
        if(head == null){
            return null;
        }
        
        ListNode dummy = new ListNode(0);
        ListNode prev = dummy;
        dummy.next = head;
        ListNode target = null;
        ListNode tmp = null;
        while(prev.next != null){
            if(target == null){
                if(x <= prev.next.val){
                    target = prev.next;
                    tmp = prev.next;
                }else{
                    prev = prev.next;
                }
            }else{
                if(tmp.next == null){
                    break;
                }
                if(tmp.next.val < x){
                    prev.next = tmp.next;
                    prev = prev.next;
                    tmp.next = tmp.next.next;
                }else{
                    tmp = tmp.next;
                }
            }
        }
        
        if(target != null){
            prev.next = target;
        }
        return dummy.next;
    }

思路
分2個(gè)鏈表,這樣思路比較清晰

public ListNode partition(ListNode head, int x) {
        if (head == null) {
            return null;
        }
        
        ListNode leftDummy = new ListNode(0);
        ListNode rightDummy = new ListNode(0);
        ListNode left = leftDummy;
        ListNode right = rightDummy;
        
        while (head != null) {
            if (head.val < x) {
                left.next = head;
                left = head;
            } else {
                right.next = head;
                right = head;
            }
            head = head.next;
        }
        
        right.next = null;
        left.next = rightDummy.next;
        return leftDummy.next;
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市驱闷,隨后出現(xiàn)的幾起案子耻台,更是在濱河造成了極大的恐慌,老刑警劉巖空另,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盆耽,死亡現(xiàn)場離奇詭異,居然都是意外死亡扼菠,警方通過查閱死者的電腦和手機(jī)摄杂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來循榆,“玉大人匙姜,你說我怎么就攤上這事》肓。” “怎么了氮昧?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長浦楣。 經(jīng)常有香客問我袖肥,道長,這世上最難降的妖魔是什么振劳? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任椎组,我火速辦了婚禮,結(jié)果婚禮上历恐,老公的妹妹穿的比我還像新娘寸癌。我一直安慰自己专筷,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布蒸苇。 她就那樣靜靜地躺著磷蛹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪溪烤。 梳的紋絲不亂的頭發(fā)上味咳,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機(jī)與錄音檬嘀,去河邊找鬼槽驶。 笑死,一個(gè)胖子當(dāng)著我的面吹牛鸳兽,可吹牛的內(nèi)容都是我干的掂铐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼揍异,長吁一口氣:“原來是場噩夢啊……” “哼堡纬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蒿秦,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤烤镐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后棍鳖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體炮叶,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年渡处,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了镜悉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡医瘫,死狀恐怖侣肄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情醇份,我是刑警寧澤稼锅,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站僚纷,受9級特大地震影響矩距,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜怖竭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一锥债、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦哮肚、人聲如沸登夫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽恼策。三九已至,卻和暖如春拼窥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蹋凝。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工鲁纠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鳍寂。 一個(gè)月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓改含,卻偏偏與公主長得像,于是被迫代替她去往敵國和親迄汛。 傳聞我的和親對象是個(gè)殘疾皇子捍壤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

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

  • 3.10 69.給出一棵二叉樹,返回其節(jié)點(diǎn)值的層次遍歷(逐層從左往右訪問) 二叉樹的層次遍歷樣例給一棵二叉樹 {3...
    mytac閱讀 1,077評論 3 3
  • 【聲明】歡迎轉(zhuǎn)載鞍爱,但請保留文章原始出處→_→文章來源:http://www.reibang.com/p/08d08...
    夢工廠閱讀 3,770評論 3 31
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)鹃觉。 張土汪:刷leetcod...
    土汪閱讀 12,745評論 0 33
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)睹逃,斷路器盗扇,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • 想變成一個(gè)漂亮的小姐姐 今天被夸瘦了 好開心 拍的武漢的照片好像大家覺得很好看 天氣可真熱 好喜歡PGone這種類...
    PearlParis閱讀 362評論 0 0