linked-list-cycle-ii (数学证明)
题意:略.
 这个题最关键的点在于后面,如何找到循环开始的节点。
这个题最关键的点在于后面,如何找到循环开始的节点。
第一阶段,先用快慢指针找到相遇的节点C。(至于为什么,了解一下欧几里德拓展解决二元不定方程。)A是表头。B是开始循环的位置。
第一次阶段的公式是: 2(x+y)=x+y+n(y+z); 注意一下:n表示快指针比慢指针多跑了n圈!
那么两边同时减去 x+y 则, x+y= n*(y+z); 注意:这里y+z表示一整圈!则 x等于 (n-1)*y+n*z; (仔细分析这个式子的含义)
当n等于1时,是不是x=z,当n=2时,是不是相当于先跑一圈,A-B剩下的等于z,依次类推更大的n
所以,当一个指针放在C点,第二个指针放在A点, 以相同的而速度向前推进时,相等处就是B点
class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        if (head == NULL) return NULL;        //空表
        ListNode *slow = head;
        ListNode *fast = head;
        while (fast&&fast->next){
            slow = slow->next;    fast = fast->next->next;
            if (slow == fast)break;            //相遇
        }
        if (fast == NULL || fast->next == NULL)return NULL;
        slow = head;
        while (slow != fast){
            slow = slow->next;
            fast = fast->next;
        }
        return slow;
    }
};
linked-list-cycle-ii (数学证明)的更多相关文章
- LeetCode解题报告:Linked List Cycle && Linked List Cycle II
		LeetCode解题报告:Linked List Cycle && Linked List Cycle II 1题目 Linked List Cycle Given a linked ... 
- Linked List Cycle && Linked List Cycle II
		Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Note ... 
- 141. Linked List Cycle&142. Linked List Cycle II(剑指Offer-链表中环的入口节点)
		题目: 141.Given a linked list, determine if it has a cycle in it. 142.Given a linked list, return the ... 
- 【LeetCode】142. Linked List Cycle II (2 solutions)
		Linked List Cycle II Given a linked list, return the node where the cycle begins. If there is no cyc ... 
- 【算法分析】如何理解快慢指针?判断linked list中是否有环、找到环的起始节点位置。以Leetcode 141. Linked List Cycle, 142. Linked List Cycle II 为例Python实现
		引入 快慢指针经常用于链表(linked list)中环(Cycle)相关的问题.LeetCode中对应题目分别是: 141. Linked List Cycle 判断linked list中是否有环 ... 
- [Leetcode Week6]Linked List Cycle II
		Linked List Cycle II 题解 题目来源:https://leetcode.com/problems/linked-list-cycle-ii/description/ Descrip ... 
- 142. Linked List Cycle II【easy】
		142. Linked List Cycle II[easy] Given a linked list, return the node where the cycle begins. If ther ... 
- LeetCode141 Linked List Cycle. LeetCode142 Linked List Cycle II
		链表相关题 141. Linked List Cycle Given a linked list, determine if it has a cycle in it. Follow up:Can y ... 
- [算法][LeetCode]Linked List Cycle & Linked List Cycle II——单链表中的环
		题目要求 Linked List Cycle Given a linked list, determine if it has a cycle in it. Follow up: Can you so ... 
- 15. Linked List Cycle && Linked List Cycle II
		Linked List Cycle Given a linked list, determine if it has a cycle in it. Follow up: Can you solve i ... 
随机推荐
- Vue 动态加载组件
			为什么要动态加载呢?而不是一次性加载呢? 一次性?你能保证你拿的内容不多,那从性能方面说还是OK的.否则,就该什么时候用,就什么时候取. 得出这想法,源于前几天上班赶产品的故事: A组件是父亲,B组件 ... 
- SQL查询语句如何能够让指定的记录排在最后
			方法如下:select * from <表名> order by case when <条件> then 1 else 0 end asc 举例:把threads表中列id值小 ... 
- 总结:JDK1.5-JDK1.8各个新特性
			JDK1.5-JDK1.8各个新特性 JDK各个版本的新特性 要了解一门语言,最好的方式就是要能从基础的版本进行了解,升级的过程,以及升级的新特性,这样才能循序渐进的学好一门语言.以下介绍一下JDK1 ... 
- Docker 轻量级图形管理软件 Portainer
			安装 docker swarm :https://www.cnblogs.com/klvchen/p/9437758.html portainer 集群启动 docker volume create ... 
- pygame编组(精灵组)Group中的常用方法介绍
			说明: 1.以下所用的Group均为Group类的对象实例 2.Group类是对AbstractGroup类的继承 sprite.py文档中描述如下: class Group(AbstractGrou ... 
- js发送请求
			1.Chrome控制台中 net::ERR_CONNECTION_REFUSED js频繁发送请求,有可能连接被拒绝,可用setTimeout,过几秒发送,给个缓冲时间 var overlayAnal ... 
- JS模拟实现数组的map方法
			昨天使用map方法的时候,突然感觉一直在直接用,也没有试试是怎么实现的,本来想直接搜一篇文章盘一下子,结果没搜到合适的,好吧,那就自己来写一下子吧 今天就来实现一个简单的map方法 首先我们来看一下m ... 
- drupal7常用函数
			1.获取当前启用的管理员主题名称: $admin_theme = variable_get('admin_theme'); 
- SuperMap iServer 扩展/JAVA API 系列博客整理
			转载:http://blog.csdn.net/supermapsupport/article/details/70158940 SuperMap iServer为广大用户提供了整套 SDK,应用开发 ... 
- 实践:配置keepalived实现主备热备份功能
			图: 配置文件: 主服务器的配置如下: global_defs { router_id NodeA}vrrp_instance VI_1 { state MASTER #设置为主服务器 interfa ... 
