题解 | #反转链表#

判断链表中是否有环

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的时候表示遍历结束,没有环,所以需要对快指针的下一个节点以及下下个节点进行判断,以免出现段错误

全部评论

相关推荐

06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
人力小鱼姐:实习经历没有什么含金量,咖啡店员迎宾这种就别写了,其他两段包装一下 想找人力相关的话,总结一下个人优势,结合校园经历里有相关性的部分,加一段自我评价
点赞 评论 收藏
分享
不亏是提前批,神仙打架,鼠鼠不配了
站队站对牛:现在92都报工艺岗了
投递韶音科技等公司8个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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