题解 | #判断链表中是否有环#

判断链表中是否有环

https://www.nowcoder.com/practice/650474f313294468a4ded3ce0f7898b9

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
#include<unordered_map>

class Solution {
public:
    bool hasCycle(ListNode *head) {
        ListNode* CountPoint = head;
	  //定义一个哈希表
        unordered_map<ListNode*,int>mymap;
        if(head->next ==nullptr){return false;}
        if(head==nullptr){return false;}
        CountPoint = CountPoint->next;
       //判断mymap是否出现重复元素,先走一遍链表,结束条件为出现重复元素或者最后一个元素指向Null
        while(mymap[CountPoint]<1 && CountPoint->next !=nullptr){
            mymap[CountPoint]++;
            CountPoint = CountPoint->next;           
        }
        if (CountPoint->next==nullptr) {return false;
        }
        else {
         return true;
        }        
    }
};

全部评论

相关推荐

码农索隆:单休一个月少休息4天,一年就是48天,平时节假日,别人3天假期,单休的两天
点赞 评论 收藏
分享
人力小鱼姐:实习经历没有什么含金量,咖啡店员迎宾这种就别写了,其他两段包装一下 想找人力相关的话,总结一下个人优势,结合校园经历里有相关性的部分,加一段自我评价
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务