328#奇偶鏈表

題目描述

給定一個(gè)單鏈表,把所有的奇數(shù)節(jié)點(diǎn)和偶數(shù)節(jié)點(diǎn)分別排在一起氨距。請注意,這里的奇數(shù)節(jié)點(diǎn)和偶數(shù)節(jié)點(diǎn)指的是節(jié)點(diǎn)編號的奇偶性棘劣,而不是節(jié)點(diǎn)的值的奇偶性俏让。

請嘗試使用原地算法完成。你的算法的空間復(fù)雜度應(yīng)為 O(1)茬暇,時(shí)間復(fù)雜度應(yīng)為 O(nodes)首昔,nodes 為節(jié)點(diǎn)總數(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é)點(diǎn)和偶數(shù)節(jié)點(diǎn)的相對順序糙俗。
  • 鏈表的第一個(gè)節(jié)點(diǎn)視為奇數(shù)節(jié)點(diǎn)勒奇,第二個(gè)節(jié)點(diǎn)視為偶數(shù)節(jié)點(diǎn),以此類推臼节。

分析

隔一個(gè)取一個(gè)元素撬陵,新建一個(gè)鏈表,把取出來的索引為偶數(shù)的元素放進(jìn)去网缝,原鏈表剩下的都是索引為奇數(shù)的元素巨税,再把兩個(gè)鏈表拼接起來,就可以得到結(jié)果粉臊。示意圖如下:

奇偶鏈表分步示意圖

源碼

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode oddEvenList(ListNode head) {
        if (head == null)   return null;
        ListNode odd = head;
        ListNode even = odd.next;
        ListNode evenHead = even;
        while (even != null && even.next != null) // 之所以不用奇指針判斷草添,是因?yàn)榕紨?shù)指針比奇數(shù)指針先到鏈表尾部
        {
            odd.next = even.next;
            odd = odd.next;
            even.next = odd.next;
            even = even.next;
        }
        odd.next = evenHead;
        
        return head;
        
    }
}

有一個(gè)小細(xì)節(jié)需要注意一下,在判斷鏈表是否走完的時(shí)候扼仲,我們要使用偶指針判斷远寸,因?yàn)樵诔跏嘉恢茫贾羔樖窃谄嬷羔樀暮竺嬉粋€(gè)位置屠凶,在若干輪的操作過后驰后,偶指針比奇指針先到達(dá)鏈表尾部。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末矗愧,一起剝皮案震驚了整個(gè)濱河市灶芝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌唉韭,老刑警劉巖夜涕,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異属愤,居然都是意外死亡女器,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門住诸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來驾胆,“玉大人涣澡,你說我怎么就攤上這事∏喂埃” “怎么了暑塑?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵吼句,是天一觀的道長锅必。 經(jīng)常有香客問我,道長惕艳,這世上最難降的妖魔是什么搞隐? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮远搪,結(jié)果婚禮上劣纲,老公的妹妹穿的比我還像新娘。我一直安慰自己谁鳍,他們只是感情好癞季,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著倘潜,像睡著了一般绷柒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上涮因,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天废睦,我揣著相機(jī)與錄音,去河邊找鬼养泡。 笑死嗜湃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的澜掩。 我是一名探鬼主播购披,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼肩榕!你這毒婦竟也來了刚陡?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤点把,失蹤者是張志新(化名)和其女友劉穎橘荠,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體郎逃,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡哥童,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了褒翰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贮懈。...
    茶點(diǎn)故事閱讀 40,133評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡匀泊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出朵你,到底是詐尸還是另有隱情各聘,我是刑警寧澤,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布抡医,位于F島的核電站繁涂,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏摩骨。R本人自食惡果不足惜疆虚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望水孩。 院中可真熱鬧镰矿,春花似錦、人聲如沸俘种。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宙刘。三九已至苍姜,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間荐类,已是汗流浹背怖现。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留玉罐,地道東北人屈嗤。 一個(gè)月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像吊输,于是被迫代替她去往敵國和親饶号。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評論 2 355

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

  • 介紹 有時(shí)候我們需要設(shè)計(jì)這樣一種數(shù)據(jù)結(jié)構(gòu):它能快速在要求位置插入或者刪除一段數(shù)據(jù)季蚂。先考慮兩種簡單的數(shù)據(jù)結(jié)構(gòu):數(shù)組和...
    lintong閱讀 1,129評論 0 1
  • 《江城》篇 也是名篇茫船。 “文宗下學(xué),生以誤講降為青” 【筆記】: “文宗下學(xué)”二句:謂學(xué)政按臨府縣考試諸生扭屁,高生因...
    倒映書影閱讀 810評論 0 0
  • 如果我沉默 這世間不再有人出聲吶喊 我的正義得不到伸張 我的苦難得不到體恤 我的委屈得不到疼惜 如果我沉默 我將放...
    未明花香閱讀 397評論 2 1
  • 各自有各自的生活 感謝你 路過我人生的征途 我是低到塵埃里的沙礫 卻有一顆不羈放縱偏愛自由的靈魂 ...
    TheAttitude閱讀 219評論 0 0