当前位置: 首页 > news >正文

有口碑的武进网站建设百度关键词搜索技巧

有口碑的武进网站建设,百度关键词搜索技巧,手机网站建设新闻,网络营销的方式都有哪些题目链接 Leetcode.剑指 Offer II 022 链表中环的入口节点 mid 题目描述 给定一个链表,返回链表开始入环的第一个节点。 从链表的头节点开始沿着 next指针进入环的第一个节点为环的入口节点。如果链表无环,则返回 null。 为了表示给定链表中的环&#…

题目链接

Leetcode.剑指 Offer II 022 链表中环的入口节点 mid

题目描述

给定一个链表,返回链表开始入环的第一个节点。 从链表的头节点开始沿着 next指针进入环的第一个节点为环的入口节点。如果链表无环,则返回 null

为了表示给定链表中的环,我们使用整数 pos来表示链表尾连接到链表中的位置(索引从 0开始)。 如果 pos-1,则在该链表中没有环。注意,pos仅仅是用于标识环的情况,并不会作为参数传递到函数中。

说明:不允许修改给定的链表。

示例 1:

在这里插入图片描述

输入:head = [3,2,0,-4], pos = 1
输出:返回索引为 1 的链表节点
解释:链表中有一个环,其尾部连接到第二个节点。

示例 2:

在这里插入图片描述

输入:head = [1,2], pos = 0
输出:返回索引为 0 的链表节点
解释:链表中有一个环,其尾部连接到第一个节点。

示例 3:

在这里插入图片描述

输入:head = [1], pos = -1
输出:返回 null
解释:链表中没有环。

提示:

  • 链表中节点的数目范围在范围 [0,1040, 10^40,104] 内
  • −105<=Node.val<=105-10^5 <= Node.val <= 10^5105<=Node.val<=105
  • pos的值为 -1或者链表中的一个有效索引

分析:快慢指针

我们用两个指针 fastslow,初始都指向 headfast每次走两步,slow每次走一步。

如果链表存在环,那么 fastslow一定会在环中相遇。

在这里插入图片描述

因为fastslow要快1步,所以当 slow走过的距离为 x + y到达相遇点时,fast其实已经在环里转了若干圈了(这里假设是 n圈)。

所以 fast走过的路程为 ,x+n∗(y+z)+yx + n * (y + z) + yx+n(y+z)+y

又因为 fast走过的路程 应该是 两倍slow走过的路程,即 x+n∗(y+z)+y=2∗(x+y)x + n * (y + z) + y = 2 * (x + y)x+n(y+z)+y=2(x+y)

化简得 : x=(n−1)∗(y+z)+zx = (n - 1) * (y + z) + zx=(n1)(y+z)+z,即从相遇点走 z的路程,再走若干圈,就是 x的路程。(我们只需要走 0 圈即可),即 x=zx = zx=z

fastslow相遇时,让 fast重新指向头节点 headfastslow同时移动,当他们再次相遇时的点,就是环的起点。

时间复杂度: O(n)O(n)O(n)

C++代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:ListNode *detectCycle(ListNode *head) {if(head == nullptr) return nullptr;ListNode *fast = head , *slow = head;while(fast && fast->next){slow = slow->next;fast = fast->next->next;//两者相遇if(slow == fast){fast = head;while(slow != fast){slow = slow->next;fast = fast->next;}return slow;}}return nullptr;}
};

Java代码:

/*** Definition for singly-linked list.* class ListNode {*     int val;*     ListNode next;*     ListNode(int x) {*         val = x;*         next = null;*     }* }*/
public class Solution {public ListNode detectCycle(ListNode head) {if(head == null) return null;ListNode fast = head;ListNode slow = head;//fast 或 fast.next 为 null , 说明链表没有环while(fast != null && fast.next != null){slow = slow.next;fast = fast.next.next;//快慢指针相遇了,fast 重新回到头节点 head,快慢指针再同时移动if(slow == fast){fast = head;while(fast != slow){fast = fast.next;slow = slow.next;}return fast;}}return null;}
}
http://www.ds6.com.cn/news/27717.html

相关文章:

  • 管理员网站后台上传本地视频互联网平台推广怎么做
  • 做点心的网站信息流投放平台
  • 镇江域名注册广州市口碑seo推广
  • 制作团购网站志鸿优化网官网
  • 杭州网站建设迅雷磁力链bt磁力天堂下载
  • 西安做网站的公司维护百度网盘电话人工服务
  • 外国黄色网站自己的网站怎么做seo
  • 重庆网站建设联系电话推广运营是做什么的
  • 免费企业名录网站手机百度账号登录入口
  • 企业网站建设费用计入哪个科目石家庄全网seo
  • 手机优化不到100怎么办网站排名优化手机
  • 国产99做视频网站长沙seo公司排名
  • 温州网页网站制作怎样在网上做推广
  • 石家庄 外贸网站建设网站维护一般怎么做
  • 企业网站快速备案服务网络营销课程培训机构
  • 做相册本哪个网站好用福州短视频seo
  • 山西省建设注册中心网站搜索关键词的软件
  • 为什么上传网站模板网站上没有文字和图片上海网络推广渠道
  • wordpress硬盘seo科技网
  • 消防有哪些网站合适做百度seo如何优化
  • 网站域名备案后公示市场营销方案范文5篇
  • 机械厂做的网站模板叫什么seo常见的优化技术
  • 重庆网站有哪些seo网络营销
  • 服务质量好的网站设计制作2022年传销最新消息
  • 网站开发 避免 字段变化 代码营销策略有哪些方面
  • 谁可以做开码网站中国万网登录入口
  • 台州网站建设外包廊坊seo排名优化
  • 免费设立网站查询网站流量的网址
  • 合肥做兼职网站设计疫情排行榜最新消息
  • 网站建设 人性的弱点网络营销工具与方法