Odd Even Linked List

栏目: 数据库 · 发布时间: 5年前

内容简介:第10天,今天的题目总感觉做过,但是翻记录又没有,难道是在学校的OJ上做的???今天的题目是好久没碰到链表的题了,这题比较简单。我们用一个新的链表来存奇数位的元素即可,而且这里没必要重新建立一个链表,只需要把原来链表里面的连接过来就好了,完成后,自然就把一个链表分成两个链表了。

第10天,今天的题目总感觉做过,但是翻记录又没有,难道是在学校的OJ上做的???

今天的题目是 Odd Even Linked List

好久没碰到链表的题了,这题比较简单。我们用一个新的链表来存奇数位的元素即可,而且这里没必要重新建立一个链表,只需要把原来链表里面的连接过来就好了,完成后,自然就把一个链表分成两个链表了。

区分奇偶数位,可以用一个 flag 来标识当前元素是奇数还是偶数,然后每移动一次就翻转该 flag ,当然更简单的是,我们循环一次移动两个元素,这样看起来会简洁一点,而且在循环内部不需要任何的条件判断,只需要在循环结束后做一些后处理即可。

class Solution {
public:
    ListNode* oddEvenList(ListNode* head) {
        if (head == nullptr || head->next == nullptr) return head;
        
        ListNode even(0);
        ListNode *p = head;
        ListNode *q = &even;
        
        while(p->next && p->next->next) {
            q->next = p->next;
            p->next = p->next->next;
            p = p->next;
            q = q->next;
        }
        if (p->next != nullptr) {
            q->next = p->next;
            q = q->next;
        }
        p->next = even.next;
        q->next = nullptr;
        return head;
    }
};

以上所述就是小编给大家介绍的《Odd Even Linked List》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

快速转行做产品经理

快速转行做产品经理

李三科 / 华中科技大学出版社 / 2018-6-1 / 39.90

互联网已经进入以产品为中心的时代,不懂技术一样做高薪产品经理。本书将满足你转行、就业、加薪的愿望。 . 作者李三科,互联网资深产品经理。2011年离开传统销售行业进入互联网行业工作,从对产品经理的工作一无所知,到成长为一名年薪几十万的资深产品经理,他对产品经理职业有着深刻的理解,也积累了丰富的学习、工作经验。本书以作者亲身经历为线索,讲解学习产品经理相关知识和工作方法的经验,同时介绍求......一起来看看 《快速转行做产品经理》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具