单链表三(判断一单链表是不是循环单链表)

 我来答
情愫A733b1ff64
2013-08-23 · 超过64用户采纳过TA的回答
知道答主
回答量:118
采纳率:0%
帮助的人:125万
展开全部
单链表的算法:给定一个单链表,它可能是一个以NULL结尾的非循环链表,也可能是一个循环结构的循环链表。已知这个链表的头指针,请编写一个函数来判断该链表属于哪类情况,该函数不得对链表本身做任何修改。 用两个指针同时遍历检查,快指针+满指针;当快指针超过满指针就是一个循环链表。让快慢两个指针从链表的头元素开始遍历,无限循环 如果快指针遇到了NULL指针 返回,这是个非循环链表 如果快指针追上了或者是超过慢指针 返回,这是一个循环链表 让慢指针前进一个节点 让快指针前进两个节点int DetermineTermination(LinkList head){ LinkList fast,slow;//快慢指针 fast=head; slow=head; while(1) { if(!fast||!fast->Next) return 0; slow=slow->Next; fast=fast->Next->Next; if(fast==slow||fast->Next==slow) return 1; }}void CricleLinkList(LinkList& head){ LinkList temp; temp=head; while(temp->Next) { temp=temp->Next; } temp->Next=head->Next->Next;}int main(){ LinkList head=(LinkList)malloc(sizeof(Node)); head->Next=NULL; head=InitLinkList(9,head);// CricleLinkList(head); cout<<"Circle Or Not:"<<DetermineTermination(head->Next); return 0;}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式