标题:判断一个链表是否有循环
只看楼主
wuhao5519
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2008-2-13
 问题点数:0 回复次数:0 
判断一个链表是否有循环
// 判断一个链表是否 有循环
/*bool hasLoop(node* p)
{
}
*/
struct node
{
    int value;
    node* next;
};

bool hasLoop(node* p)  //步长法
{
    node* temp = p;
    if(!temp->next)
        return false;
    node* temp2 = temp->next;
    if(!temp2->next)
        return false;
    return true;
}
void main()
{
    node* p=new node[100];
    for(int i=0;i<100;i++)
    {
        p[i].value=i+1;
        p[i].next = p+i+1;
        p[i-1].next=p+1;  // 值  或  NULL  
    }
    if(hasLoop(p))
        cout<<"Loop"<<endl;
    else
        cout<<"Not Loop"<<endl;
}
搜索更多相关主题的帖子: 链表 node next temp bool 
2008-02-13 22:37



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-199835-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.381281 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved