码迷,mamicode.com
首页 > 其他好文 > 详细

8.判断单链表是否有环(6形状)?如何找到环的“起始”点?如何知道环的长度?

时间:2016-09-30 07:38:30      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

8.判断单链表是否有环(6形状)?如何找到环的“起始”点?如何知道环的长度?

技术分享

思路:

        注意分析题意,题意并非是说单链表完全成O形状的环,而是说单链表成6形状的环。

        首先判断是否有环:为此我们建立两个指针,从Head一起向前跑,一个步长为1,一个步长为2,用

  while(直到步长2的跑到结尾)
{
检查两个指针是否相等,直到找到为止。
}

来进行判断。

            原因是,在这场跑步中,结束循环有两种可能,其一是原来无环,所以2先跑到结尾,因为2比1快,二者不可能相等。其二是原来是有环的,因为这场赛跑永远没有z终点,但是在环中,由于2比1快,因而必定套圈,也即2追上了1,这在无环中是不可能出现的情况。

           而进行计算环的长度,只要找到交汇点,然后在圈中跑一次就可以了。

int getCircleLength(Node* cross)

bool judgeCircleExists(Node* Head)

//单链表成环,计算环的长度(输入的参数为成环的交汇点)
int getCircleLength(Node* cross)
{
     int len=1;
     Node* p=cross;
     while(p->next!=cross)    //不能写作 p->next!=p
     {
          len++;
          p=p->next;
     }
     return len;
}   

  

 

//判断单链表是否有环,并且返回环的长度
bool judgeCircleExists(Node* Head,int &len)
{
     if(Head==NULL)    //空链
          return false;
     else if(Head->next==Head)    //1个节点且成环
          return true;
     else if(Head->next==NULL)    //1个节点不成环
          return false;

     //至少两个节点情形
     //初始化跑步机
     Node* p1=Head;              //跑步者1号,跑到第1个节点
     Node* p2=Head->next;    //跑步者2号,跑到第2个节点
     while(p2!=NULL&&p2->next!=NULL)  //利用了&&短路
     {
          p1=p1->next;
          p2=p2->next->next;
          if(p1==p2)
          {
               //此时p1(p2)即为交汇点
               len=getCircleLength(p1);
               return true;
          }
     }
     return false;
}    

  

 

8.判断单链表是否有环(6形状)?如何找到环的“起始”点?如何知道环的长度?

标签:

原文地址:http://www.cnblogs.com/claremore/p/5922461.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!