链表问题 swap 2 pairs以及判断链表是否有环

Paste_Image.png
ListNode* swapPairs(ListNode* head) {
        if (head == NULL)
            return NULL;
        ListNode* pre = new ListNode(0);
        ListNode* res = pre;
        pre->next = head;
        int count = 0;
        //用一个指针作为头指针
        //pre作为前一部分的最后一个元素 不断迭代
        while (head)
        {
            if (head->next)
            {
                pre->next = head->next;
                ListNode* temp = head->next->next;
                ListNode* k = head->next;
                head->next = NULL;
                k->next = head;
                pre = head;
                head = temp;
            }
            else
            {
                pre->next = head;
                head = head->next;
            }
            count++;
        }
        return res->next;
    }

上面为第一种方法,第二种使用递归的方法
这个代码应该是java的 不过转化为c++应该也很快

public ListNode swapPairs(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        
        ListNode newhd = head.next;
        head.next = swapPairs(newhd.next);
        newhd.next = head;
        return newhd;
}
Paste_Image.png

判断是否有环 两种方法:
1)两个哨兵,一个哨兵走得快,一个哨兵走得慢

bool hasCycle(ListNode *head) {
        if(head==NULL||head->next==NULL)
        return false;
        ListNode* l=head;
        ListNode* r=head;
        while(r&&l)
        {
            if(r->next==NULL)
            break;
            l=l->next;
            r=r->next->next;
            if(l==r)
            return true;
        }
        return false;
    }

2)使用unordered_set存储listNode指针,判断之前是否有指针存在,使用find函数
该函数可以得到环的入口


ListNode *detectCycle(ListNode *head) {
       if (head == NULL || head->next == NULL)
        return NULL;
    ListNode* p = head;
    unordered_set<ListNode*> dt;
    while (p)
    {
        if (dt.find(p) != dt.end())
            return p;
        dt.insert(p);
        p = p->next;
    }
    return NULL;
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,533评论 0 6
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,767评论 0 33
  • 指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; ...
    朱森阅读 3,470评论 3 44
  • 题目类型 a.C++与C差异(1-18) 1.C和C++中struct有什么区别? C没有Protection行为...
    阿面a阅读 7,706评论 0 10
  • 罗森家中 罗森还是没有醒过来,他躺在床上,双眸紧闭,眉头微锁。张正已经把他身上的血迹擦净,换上了一套干净的家居服,...
    樹里阅读 168评论 0 0