A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 范二青年 中级黑马   /  2013-12-10 22:07  /  1047 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 范二青年 于 2013-12-10 22:12 编辑

今天看到一个关于链表的数据结构题,就是说一个怎样快速判断一个单向链表中是否存在环?

4 个回复

正序浏览
  1. /*  链表的头指针为h  */
  2. if((NULL == h) || (NULL == h->next))
  3. /* 头指针为空或者链表中只有一个节点,则无环,退出 */
  4. {
  5.               return 0;
  6. }         

  7. p = q = h; /* 设p和 q 指针, 均指向头结点 */
  8. while(1)
  9. {
  10.     p = p->next;
  11.     q = (q->next)->next;
  12.     if((NULL == p) || (NULL == q))
  13.     {
  14.         printf(“No Ringn”); /* 链表中无环, 退出 */
  15.         return 0;
  16. }
  17.     if(p == q) /* 链表中有环 */
  18.     {
  19.        printf(“Ring occurred\n”);
  20.        return 1;
  21. }
  22. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
简★零度 + 1

查看全部评分

回复 使用道具 举报
一个人旅行 发表于 2013-12-10 22:09
设置两个指针,初始值都指向头,一个快一个慢,看是否相遇

哦,谢谢,明白了!
回复 使用道具 举报
一个人旅行 发表于 2013-12-10 22:09
设置两个指针,初始值都指向头,一个快一个慢,看是否相遇

哦,谢谢,明白了!
回复 使用道具 举报
设置两个指针,初始值都指向头,一个快一个慢,看是否相遇
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马