328. 奇偶聯(lián)表

題目

給定一個單鏈表,把所有的奇數(shù)節(jié)點和偶數(shù)節(jié)點分別排在一起婴谱。請注意冕屯,這里的奇數(shù)節(jié)點和偶數(shù)節(jié)點指的是節(jié)點編號的奇偶性寂诱,而不是節(jié)點的值的奇偶性。

請嘗試使用原地算法完成安聘。你的算法的空間復(fù)雜度應(yīng)為 O(1)痰洒,時間復(fù)雜度應(yīng)為 O(nodes),nodes 為節(jié)點總數(shù)浴韭。

示例

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

審題

1. 邏輯上丘喻,奇偶index分開,也就是分成奇數(shù)鏈表和偶數(shù)鏈表念颈,然后兩個鏈表合并泉粉。
2. 空間復(fù)雜度O(1),不能創(chuàng)建新的鏈表榴芳。
3. 時間復(fù)雜度O(n)嗡靡,不能嵌套循環(huán)。

算法

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* oddEvenList(ListNode* head) {
        if (head == nullptr || head->next == nullptr) {
            return head;
        }

        ListNode* odd_node = head;              // 奇數(shù)鏈表
        ListNode* even_node = head->next;       // 偶數(shù)鏈表
        ListNode* even_node_head = even_node;   // 偶數(shù)鏈表頭窟感,鏈表合并使用
        while (odd_node->next != nullptr && even_node->next != nullptr) {
            // 奇數(shù)鏈表的next為原鏈接偶數(shù)index的next
            odd_node->next = even_node->next;
            odd_node = odd_node->next;

            // 偶數(shù)鏈表的next為原鏈接奇數(shù)index的next
            even_node->next = odd_node->next;
            even_node = even_node->next;
        }

        // 奇偶鏈表合并
        odd_node->next = even_node_head;

        return head;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末讨彼,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子柿祈,更是在濱河造成了極大的恐慌哈误,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件躏嚎,死亡現(xiàn)場離奇詭異蜜自,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)紧索,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進(jìn)店門袁辈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來菜谣,“玉大人珠漂,你說我怎么就攤上這事晚缩。” “怎么了媳危?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵荞彼,是天一觀的道長。 經(jīng)常有香客問我待笑,道長鸣皂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任暮蹂,我火速辦了婚禮寞缝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘仰泻。我一直安慰自己荆陆,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布集侯。 她就那樣靜靜地躺著被啼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪棠枉。 梳的紋絲不亂的頭發(fā)上浓体,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天,我揣著相機(jī)與錄音辈讶,去河邊找鬼命浴。 笑死,一個胖子當(dāng)著我的面吹牛贱除,可吹牛的內(nèi)容都是我干的咳促。 我是一名探鬼主播,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼勘伺,長吁一口氣:“原來是場噩夢啊……” “哼跪腹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起飞醉,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤冲茸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后缅帘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體轴术,經(jīng)...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年钦无,在試婚紗的時候發(fā)現(xiàn)自己被綠了逗栽。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡失暂,死狀恐怖彼宠,靈堂內(nèi)的尸體忽然破棺而出鳄虱,到底是詐尸還是另有隱情,我是刑警寧澤凭峡,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布拙已,位于F島的核電站,受9級特大地震影響摧冀,放射性物質(zhì)發(fā)生泄漏倍踪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一索昂、第九天 我趴在偏房一處隱蔽的房頂上張望建车。 院中可真熱鬧,春花似錦椒惨、人聲如沸癞志。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽凄杯。三九已至,卻和暖如春秉宿,著一層夾襖步出監(jiān)牢的瞬間戒突,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工描睦, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留膊存,地道東北人。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓忱叭,卻偏偏與公主長得像隔崎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子韵丑,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,507評論 2 359

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