010给定一个循环链表,实现一个算法返回这个环的开始结点 (keep it up)

给定一个循环链表,实现一个算法返回这个环的开始结点。


定义:


循环链表:链表中一个结点的指针指向先前已经出现的结点,导致链表中出现环。


例子:


输入:A -> B -> C -> D -> E -> C [结点C在之前已经出现过]


输出:结点C


可以用一个map<node*,bool> 就解决问题了。

下面是编程之美上一种奇特的解法:快慢指针解法。

代码:

struct SNode
{
	int    data;
	SNode* next;
};

SNode* findCirleStart(const SNode* vHead)
{
	if (vHead->next == NULL) return NULL;

	SNode* Fast = vHead;
	SNode* Slow = vHead;

	while (Slow && Fast->next)
	{
		Slow = Slow->next;
		Fast = Fast->next->next;
		if (Slow == Fast) break;
	}

	Slow = vHead;
	while (Slow != Fast)
	{
		Slow = Slow->next;
		Fast = Fast->next;
	}

	return Fast;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值