美文网首页
5_12链表判环

5_12链表判环

作者: X_Y | 来源:发表于2017-09-15 22:43 被阅读3次

如何判断一个单链表是否有环?有环的话返回进入环的第一个节点的值,无环的话返回-1。如果链表的长度为N,请做到时间复杂度O(N),额外空间复杂度O(1)。

给定一个单链表的头结点head(注意另一个参数adjust为加密后的数据调整参数,方便数据设置,与本题求解无关),请返回所求值。

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/
class ChkLoop {
public:
    int chkLoop(ListNode* head, int adjust) {
        // write code here
        if(!head){return -1;}
        
        ListNode *p1 = head, *p2 = head;
        while(p2){

            if(p2->next){
                p2 = p2->next->next;
            }else{
                return -1;
            }
            p1 = p1->next;
            if(p2 == p1){
                break;
            }
        }
        if(NULL == p2){
            return -1;
        }
        p2 = head;
        while(p1 != p2){
            p1 = p1->next;
            p2 = p2->next;
        }
        return p1->val;
    }
};

相关文章

  • 5_12链表判环

    如何判断一个单链表是否有环?有环的话返回进入环的第一个节点的值,无环的话返回-1。如果链表的长度为N,请做到时间复...

  • 链表判环

    如何判断一个单链表是否有环?有环的话返回进入环的第一个节点的地址,无环的话返回空。如果链表的长度为N,请做到时间复...

  • Java实现有环的单向链表,并判断单向链表是否有环

    Java实现有环的单向链表,并判断单向链表是否有环 有一个单向链表,链表当中有可能出现环,就像下图这样。我们如何判...

  • 链表

    1 合并两个链表 2 链表判环 并返回入环节点的值 3 两个无环单链表是否相交 4 合并两个有序链表 5 链表排序

  • 面试题23:链表中环的入口节点

    一个链表中包含环,请找出该链表的环的入口结点。 思路一:利用set和map判重 基本思路:先快慢节点判断链表是否有...

  • 转载 闲聊判圈算法

    转载 闲聊判圈算法floyd(Floyd cycle detection) 问题:如何检测一个链表是否有环,...

  • 算法题面试复习

    算法模块 1. 链表 1. 链表翻转 2. 单链表判断是不是环+求环位置+求环长度 以图片为例,假设环入口距离链表...

  • 链表算法

    定位链表中间节点 链表反转 链表是否有环, 返回的是环的位置,0代表没有环

  • 链表算法面试?看我就够了!——链表中存在环问题

    链表中存在环问题 3.1 判断链表是否有环 单链表中的环是指链表末尾的节点的 next 指针不为 NULL ,而是...

  • 判环算法以及链表常见算法题

    由于涉及到Floyd判环算法,故先简单阐述一下Floyd判环算法原理。Floyd判环算法算法原理:设置两个指针同时...

网友评论

      本文标题:5_12链表判环

      本文链接:https://www.haomeiwen.com/subject/vtgesxtx.html