2020-07-15 leetcode 328. 奇偶鏈表

給定一個單鏈表刀闷,把所有的奇數(shù)節(jié)點和偶數(shù)節(jié)點分別排在一起。請注意仰迁,這里的奇數(shù)節(jié)點和偶數(shù)節(jié)點指的是節(jié)點編號的奇偶性甸昏,而不是節(jié)點的值的奇偶性。

請嘗試使用原地算法完成徐许。你的算法的空間復(fù)雜度應(yīng)為 O(1)施蜜,時間復(fù)雜度應(yīng)為 O(nodes),nodes 為節(jié)點總數(shù)雌隅。

示例 1:

輸入: 1->2->3->4->5->NULL
輸出: 1->3->5->2->4->NULL

示例 2:

輸入: 2->1->3->5->6->4->7->NULL 
輸出: 2->3->6->7->1->5->4->NULL

說明:

  • 應(yīng)當(dāng)保持奇數(shù)節(jié)點和偶數(shù)節(jié)點的相對順序翻默。
  • 鏈表的第一個節(jié)點視為奇數(shù)節(jié)點,第二個節(jié)點視為偶數(shù)節(jié)點澄步,以此類推冰蘑。

思路:
一個 LinkedList 需要一個頭指針和一個尾指針來支持雙端操作。我們用變量 head 和 odd 保存奇鏈表的頭和尾指針村缸。 evenHead 和 even 保存偶鏈表的頭和尾指針祠肥。算法會遍歷原鏈表一次并把奇節(jié)點放到奇鏈表里去、偶節(jié)點放到偶鏈表里去。遍歷整個鏈表我們至少需要一個指針作為迭代器仇箱。這里 odd 指針和 even 指針不僅僅是尾指針县恕,也可以扮演原鏈表迭代器的角色。

image.png

解法:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode oddEvenList(ListNode head) {
        if(head==null){return head;}
         ListNode odd = head, even = head.next, evenHead = even;
        while(even!=null && even.next != null){
            odd.next = even.next;
            odd = odd.next;
            even.next = odd.next;
            even = even.next;
        }
        odd.next = evenHead;
        return head;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末剂桥,一起剝皮案震驚了整個濱河市忠烛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌权逗,老刑警劉巖美尸,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異斟薇,居然都是意外死亡师坎,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門堪滨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胯陋,“玉大人,你說我怎么就攤上這事袱箱《羟牵” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵发笔,是天一觀的道長盟萨。 經(jīng)常有香客問我,道長了讨,這世上最難降的妖魔是什么鸯旁? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮量蕊,結(jié)果婚禮上铺罢,老公的妹妹穿的比我還像新娘。我一直安慰自己残炮,他們只是感情好韭赘,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著势就,像睡著了一般泉瞻。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上苞冯,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天袖牙,我揣著相機(jī)與錄音,去河邊找鬼舅锄。 笑死鞭达,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播畴蹭,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼坦仍,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了叨襟?” 一聲冷哼從身側(cè)響起繁扎,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎糊闽,沒想到半個月后梳玫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡右犹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年汽纠,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片傀履。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖莉炉,靈堂內(nèi)的尸體忽然破棺而出钓账,到底是詐尸還是另有隱情,我是刑警寧澤絮宁,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布梆暮,位于F島的核電站,受9級特大地震影響绍昂,放射性物質(zhì)發(fā)生泄漏啦粹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一窘游、第九天 我趴在偏房一處隱蔽的房頂上張望唠椭。 院中可真熱鬧,春花似錦忍饰、人聲如沸贪嫂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽力崇。三九已至,卻和暖如春赢织,著一層夾襖步出監(jiān)牢的瞬間亮靴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工于置, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留茧吊,地道東北人。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像饱狂,于是被迫代替她去往敵國和親曹步。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355