
#includebool hasCycle(struct ListNode* head ) { // write code here struct ListNode *p = NULL; struct ListNode *pp = NULL; //空链表的判断 if(head == NULL) { return false; } p = pp =head; while( pp->next != NULL && pp->next->next != NULL) { //pp移动的末尾出现NULL时表示没有环 pp = pp->next->next; p = p->next; if(p == pp) { p = NULL; pp = NULL; return true; } } p = NULL; pp = NULL; return false; } 代码的关键在对链表的安全处理: 1、单链表为空的时候,对head节点进行判断 2、链表指针的判断,当使用快慢指针的时候,在无环的情况下需要对快指针进行范围的判断 快指针的的下一个指向NULL的时候表示遍历结束,没有环,所以需要对快指针的下一个节点以及下下个节点进行判断,以免出现段错误
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)