题解 | #反转链表#

判断链表中是否有环

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

#include <stdbool.h> /**

  • struct ListNode {
  • int val;
  • struct ListNode *next;
  • };
  • C语言声明定义全局变量请加上static,防止重复定义 */

/** *

  • @param head ListNode类
  • @return bool布尔型 / bool 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的时候表示遍历结束,没有环,所以需要对快指针的下一个节点以及下下个节点进行判断,以免出现段错误

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 11:35
程序员小白条:话太多,没实力和学历,差不多回答回答就行了,身份地位不一样
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
昨天 11:29
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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