C语言:带你轻松干掉 腾讯笔试大题 带环链表

简介: C语言:带你轻松干掉 腾讯笔试大题 带环链表

链表的分类:

链表的种类总共有八种情况有以下组成 (带头/不带头  单向/双向  循环/不循环)

9a361d0107de466fae0b8fd83b6c0080.png


带环链表与循环链表不同  带环链表 不好找到入环的节点 它是在中间进入循环,而循环链表你只需遍历它的下一个是不是头就能找到了

所以内 带环链表是非常危险的,因为你一旦去运行 就肯定是死循环的 而且我们还不知道这个环是从哪里开始的 了解完带环链表的结构后 我们来看一下这个题目

这个是判断有无环力扣

这个是判断有无环并返回入环的节点力扣


这两个题的过程十分的简单但你要明白其中的道理还是有点难度的

首先给大家提一下 这个题是用 快慢指针 

快慢指针 -- >  fast / slow

提个问题 :

如果 fast 一次走 2 步 slow 一次走 1 步 进环后 fast 能追上 slow

如果 fast 一次走 3 步 slow 一次走 1 步 进环后 fast 能追上 slow

如果 fast 一次走 4 步 slow 一次走 1 步 进环后 fast 能追上 slow

能得话请证明? 不能请说明理由? 这道题更重要的是证明


6d46b265b94947ab87bc7573421c15b3.png27625b46e6284222b566ca9b2cb54e49.png


大家可以思考一下其实 x 的长度就是当slow进环时fast与它的距离:每一次fast与slow的距离减一, 那slow每次走1步, 走了x步被追上, 不就是经过了x次嘛,经过了x次被追上而每一次他们的距离都会减一 是不是减去的距离是 x*1, 这减去的距离不就是 slow进环时fast与它的距离 嘛 怎么样这样说大家能理解嘛 (注意这里我们设定的是fast走2步 slow走1步 这样fast才是肯定能够追得上slow的)(看上面的的图理解不清楚的话可以看看下面的图)

3b9e5a6f226b42769f7171212b3ff4dc.png

这里的相对速度V取1时这些等式才是肯定成立的 换成其他就有可能不成立了写在这儿主要为了方便大家理解

根据之前得出的结果到相遇时 slow走L+X步 fast走L+N*C+X步  

因为fast每次比slow多走一步 最终相遇的时候 fast走过的距离是slow走过的距离的二倍

2×(L+X)=L+N*C+X

得出L+X=N*C

这个公式是有用处的哦 在我们解决寻找入环点这个问题时会对我们有帮助

再推导 L=N*C-X => 意味着再相遇的地方(meet) 和 链表开头的地方 (head) 两个指针会在入环点相遇: 

8b6c1aef48f54486bf364af817605957.png

 这个等式的意思: meet和head同时走 meet走之前N-1圈加上Z的距离与head在入环点相遇

bbc82eb27f204710b65e9c57e289beb4.png

 现在来看我们的这两道题:

3b6e31b873ed4994a55e49dff3984dd0.png

90fd3afb18734d25828502c20903a5ab.png

这样咱们的带环链表就解决了 其实还有另一种方法 要借用到两个链表找相交点的知识点就留给大家去思考了

感谢大家能够看到这里 !祝大家都能收到自己心仪大厂的offer !事业进步!学业进步!

目录
相关文章
|
3月前
|
存储 缓存 前端开发
【数据结构/C语言】深入理解 双向链表
【数据结构/C语言】深入理解 双向链表
|
10天前
|
存储 C语言
C语言程序设计核心详解 第九章 结构体与链表概要详解
本文档详细介绍了C语言中的结构体与链表。首先,讲解了结构体的定义、初始化及使用方法,并演示了如何通过不同方式定义结构体变量。接着,介绍了指向结构体的指针及其应用,包括结构体变量和结构体数组的指针操作。随后,概述了链表的概念与定义,解释了链表的基本操作如动态分配、插入和删除。最后,简述了共用体类型及其变量定义与引用方法。通过本文档,读者可以全面了解结构体与链表的基础知识及实际应用技巧。
|
10天前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。
|
16天前
|
存储 测试技术 C语言
C语言实现链表的各种功能
本文详细介绍了如何使用C语言实现链表的各种功能,包括链表节点结构的定义与操作函数的实现。链表作为一种常用的数据结构,具有节点自由插入删除、动态变化等特点。文中通过`link_list.h`和`link_list.c`两个文件,实现了链表的初始化、插入、删除、查找、修改等核心功能,并在`main.c`中进行了功能测试。这些代码不仅展示了链表的基本操作,还提供了丰富的注释帮助理解,适合作为学习链表的入门资料。
|
6天前
|
C语言
C语言里的循环链表
C语言里的循环链表
|
1月前
|
存储 C语言
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
|
2月前
|
存储 数据管理 C语言
C语言实战 | 使用链表完成“贪吃蛇”游戏
【7月更文挑战第1天】整体思维,即系统思维,强调以整体视角理解事物。在编程中,结构体体现这种思想,将相关变量打包处理。示例展示了如何用链表而非数组实现“贪吃蛇”游戏,链表提供了更灵活的动态数据管理。一系列代码图片详细描绘了链表结构体在游戏中的应用,包括节点定义、移动、碰撞检测等,凸显了使用链表的优势和代码的清晰组织。
32 0
C语言实战 | 使用链表完成“贪吃蛇”游戏
|
3月前
|
存储
数据结构——双向链表(C语言版)
数据结构——双向链表(C语言版)
26 2
|
3月前
|
算法 C语言
数据结构——单向链表(C语言版)
数据结构——单向链表(C语言版)
37 2
|
4月前
|
存储 C语言 Python