leetcode链表小练(1.反转链表2.链表的中间节点3.合并两个有序链表4.环形链表①5.环形链表②)详解 (୨୧• ᴗ •͈)◞︎ᶫᵒᵛᵉ ♡

本文主要是介绍leetcode链表小练(1.反转链表2.链表的中间节点3.合并两个有序链表4.环形链表①5.环形链表②)详解 (୨୧• ᴗ •͈)◞︎ᶫᵒᵛᵉ ♡,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一.反转链表

思路一反转指针反向:

思路二头插法:

二.链表的中间节点:

三.合并两个有序数组: 

 思路一:从头开始,取两个链表中小的那个尾插到新链表。定义指针head,tail指向空,代表新链表的头结点。

思路二:创建一个空的头指针(哨兵位),优化代码 :

 四.环形链表①:

 五.环形链表②:


分享几个链表经典问题给大家,有不足的地方欢迎指出~感谢支持 づ♡ど

 

一.反转链表

题目:

 

思路一反转指针反向:

设置三个指针变量n1,n2,n3;分别指向NULL,第一个节点,第二个节点。将第n2的next指向n1,n1给n2,n2给n3,然后n3指向下一个节点,当n3=NULL是就不用在移动了,总的循环终止条件是n2!=NULL.

 

代码解释:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* reverseList(struct ListNode* head){if(head==NULL)//首先判断头结点是否为空return NULL;//空就返回空struct ListNode* n1=NULL,*n2=head,*n3=n2->next;while(n2)//结束条件{n2->next=n1;//迭代过程n1=n2;n2=n3;if(n3)n3=n3->next;}return n1;
}

 

思路二头插法:

定义一个指针newHead指向空,cur指向头结点,next则是cur的下一个节点。接着再循环将cur的next指向newHead,newHead=cur,cur=next,当循环到cur=NULL时就结束。

 代码解释:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* reverseList(struct ListNode* head){struct ListNode* cur=head;struct ListNode* newHead=NULL;while(cur)//判断条件为cur!=NULL;{struct ListNode* next=cur->next;//头插cur->next=newHead;newHead=cur;cur=next;}return newHead;
}

二.链表的中间节点:

题目:

思路:快慢指针 

 代码解释:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* middleNode(struct ListNode* head){struct ListNode* slow=head,*fast=head;//如果快指针当前为空或下一个为空就跳出循环,分别对应奇数和偶数情况while(fast!=NULL && fast->next!=NULL){//慢指针走一步快指针走两步slow=slow->next;fast=fast->next->next;}return slow;
}

三.合并两个有序数组: 

题目:

 思路一:从头开始,取两个链表中小的那个尾插到新链表。定义指针head,tail指向空,代表新链表的头结点。

代码解释: 

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) 
{if(list1==NULL)return list2;//如果其中一个链表为空就返回另一个if(list2==NULL)return list1;struct ListNode* head=NULL,*tail=NULL;while(list1 !=NULL && list2 !=NULL)//注意这里得返回条件是二者都不为空{if(list1->val < list2->val)//去取链表中小的那个进行尾插{if(tail==NULL){head=tail=list1;}else {tail->next=list1;tail=tail->next;}list1=list1->next;//取完后要将当前的指针后移一位}else{if(tail==NULL){head=tail=list2;}else{tail->next=list2;tail=tail->next;}list2=list2->next;取完后要将当前的指针后移一位}}if(list1)//如果取完后其中一个不为空,就直接插入到新链表,原因是这两链表本就有序tail->next=list1;//剩下的必然比之前节点的数据大if(list2)tail->next=list2;return head;
}

思路二:创建一个空的头指针(哨兵位),优化代码 :

代码解释:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) 
{if(list1==NULL)return list2;if(list2==NULL)return list1;struct ListNode* head=NULL,*tail=NULL;//创建一个哨兵位head=tail=(struct ListNode*)malloc(sizeof(struct ListNode));while(list1!=NULL && list2!=NULL){if(list1->val < list2->val){tail->next=list1;list1=list1->next;}else{tail->next=list2;list2=list2->next;}tail=tail->next;}if(list1)tail->next=list1;if(list2)tail->next=list2;//存储第一个节点元素的位置,将哨兵位的空间释放struct ListNode* first=head->next;free(head);return first;//返回第一个节点
}

 四.环形链表①:

题目: 

思路: 快慢指针与追及,当快指针等于慢指针是,说明有环,否则无环

代码解释: 

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
bool hasCycle(struct ListNode *head)//bool类型返回正误{//定义一个快慢指针struct ListNode* fast=head,* slow=head;while(fast!=NULL && fast->next!=NULL){//如果二者相遇,就返回ture,否则就返回false;fast=fast->next->next;slow=slow->next;if(fast==slow)return true;}return false;
}

 五.环形链表②:

题目:

 思路:本题是求环的起始位置。运用快慢指针,先判断是否有环,接着根据路程可知慢指针是快指针速度的1/2,列出计算式可知,慢指针从head开始走x的距离时,fast在环中与slow相遇的位置距离环的起始位置为z,等于slow走过的距离。当二则再次相遇时,该点就是环的起始位置

图解: 

 

 代码解释:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode *detectCycle(struct ListNode *head) 
{struct ListNode* fast=head,*slow=head;while(fast && fast->next){slow=slow->next;fast=fast->next->next;if(slow==fast)//先找到环中相遇点{slow=head;//slow的位置置于头,同时将slow和fast的书读都设为1while(slow!=fast)//二者必将相遇与开始入环的第一个节点{slow=slow->next;fast=fast->next;}return slow;}}return NULL;//如果找不到就返回空
}

博客到这里也是结束了,喜欢的小伙伴可以点赞加关注支持下博主,这对我真的很重要~~

这篇关于leetcode链表小练(1.反转链表2.链表的中间节点3.合并两个有序链表4.环形链表①5.环形链表②)详解 (୨୧• ᴗ •͈)◞︎ᶫᵒᵛᵉ ♡的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/554387

相关文章

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

Go 1.23中Timer无buffer的实现方式详解

《Go1.23中Timer无buffer的实现方式详解》在Go1.23中,Timer的实现通常是通过time包提供的time.Timer类型来实现的,本文主要介绍了Go1.23中Timer无buff... 目录Timer 的基本实现无缓冲区的实现自定义无缓冲 Timer 实现更复杂的 Timer 实现总结在

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Apache伪静态(Rewrite).htaccess文件详解与配置技巧

《Apache伪静态(Rewrite).htaccess文件详解与配置技巧》Apache伪静态(Rewrite).htaccess是一个纯文本文件,它里面存放着Apache服务器配置相关的指令,主要的... 一、.htAccess的基本作用.htaccess是一个纯文本文件,它里面存放着Apache服务器

Java中有什么工具可以进行代码反编译详解

《Java中有什么工具可以进行代码反编译详解》:本文主要介绍Java中有什么工具可以进行代码反编译的相关资,料,包括JD-GUI、CFR、Procyon、Fernflower、Javap、Byte... 目录1.JD-GUI2.CFR3.Procyon Decompiler4.Fernflower5.Jav

golang panic 函数用法示例详解

《golangpanic函数用法示例详解》在Go语言中,panic用于触发不可恢复的错误,终止函数执行并逐层向上触发defer,最终若未被recover捕获,程序会崩溃,recover用于在def... 目录1. panic 的作用2. 基本用法3. recover 的使用规则4. 错误处理建议5. 常见错

pycharm远程连接服务器运行pytorch的过程详解

《pycharm远程连接服务器运行pytorch的过程详解》:本文主要介绍在Linux环境下使用Anaconda管理不同版本的Python环境,并通过PyCharm远程连接服务器来运行PyTorc... 目录linux部署pytorch背景介绍Anaconda安装Linux安装pytorch虚拟环境安装cu