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

国外mod大型网站企业培训师

国外mod大型网站,企业培训师,绵阳哪里可以做网站的地方,专业的建网站的公司给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1] 示例 2: 输入:head [1,2] 输出:[2,1] 示例 3: 输入…

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
 

示例 1:

 


输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
示例 2:


输入:head = [1,2]
输出:[2,1]
示例 3:

 

输入:head = []
输出:[]
 

提示:

链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000
 

进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/reverse-linked-list

思路:

        如果再定义一个新的链表,实现链表元素的反转,其实这是对内存空间的浪费。

        其实只需要改变链表的next指针的指向,直接将链表反转 ,而不用重新定义一个新的链表,如图所示:

        之前链表的头节点是元素1, 反转之后头结点就是元素5 ,这里并没有添加或者删除节点,仅仅是改变next指针的方向。

        那么接下来看一看是如何反转的呢?

         首先定义一个cur指针,指向头结点,再定义一个pre指针,初始化为null。

然后就要开始反转了,首先要把 cur->next 节点用tmp指针保存一下,也就是保存一下这个节点。

        为什么要保存一下这个节点呢,因为接下来要改变 cur->next 的指向了,将cur->next 指向pre ,此时已经反转了第一个节点了。

        接下来,就是循环走如下代码逻辑了,继续移动pre和cur指针。

        最后,cur 指针已经指向了null,循环结束,链表也反转完毕了。 此时我们return pre指针就可以了,pre指针就指向了新的头结点。

这里列举了两种方式:

①双指针法

class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode* temp; // 保存cur的下一个节点ListNode* cur = head;ListNode* pre = NULL;while(cur) {temp = cur->next;  // 保存一下 cur的下一个节点,因为接下来要改变cur->nextcur->next = pre; // 翻转操作// 更新pre 和 cur指针pre = cur;cur = temp;}return pre;}
};

 ②递归法:

class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode* temp; // 保存cur的下一个节点ListNode* cur = head;ListNode* pre = NULL;while(cur) {temp = cur->next;  // 保存一下 cur的下一个节点,因为接下来要改变cur->nextcur->next = pre; // 翻转操作// 更新pre 和 cur指针pre = cur;cur = temp;}return pre;}
};

        我们可以发现,上面的递归写法和双指针法实质上都是从前往后翻转指针指向,其实还有另外一种与双指针法不同思路的递归写法:从后往前翻转指针指向。

代码如下:

class Solution {
public:ListNode* reverseList(ListNode* head) {// 边缘条件判断if(head == NULL) return NULL;if (head->next == NULL) return head;// 递归调用,翻转第二个节点开始往后的链表ListNode *last = reverseList(head->next);// 翻转头节点与第二个节点的指向head->next->next = head;// 此时的 head 节点为尾节点,next 需要指向 NULLhead->next = NULL;return last;}
}; 
http://www.yayakq.cn/news/989129/

相关文章:

  • 网站建设怎么汇报新浪网站源代码
  • 南宁做网站外包wordpress调用导航代码
  • php做数据网站查询企业信息
  • 找图片素材网站wordpress中文对照
  • 青海省住房与城乡建设厅网站国际战事最新消息
  • phpmysql网站开发实例山东济南网站制作
  • 长沙专业建网站公司dw网页制作表单
  • 贵州网站开发哪家好创意网站 案例 下载
  • 徐州网站建设网络推广图片大全
  • 电子商务网站的功能分析修改目录 wordpress
  • 做外贸网站卖什么货好呢个人网站建设联系电话
  • 制作网页网站的软件是免费做网站txt外链
  • 响应的网站wordpress主题 演示数据库
  • 一起做陶瓷的网站网站访客跟踪
  • 涡阳在北京做网站的名人台州做网站seo的
  • 影视会员代理平台网站wordpress边栏固定
  • 网站优化改版容桂做网站
  • 做网站卖广告位赚钱泰安市景区建设网站
  • 深圳网站建设服务中心官网软件开发培训机构有哪些
  • 外贸网站打开速度wordpress个人简历
  • 服装网站建设背景seo入门视频
  • 长沙网站排名推广网站首页适合vue做吗
  • 房产网站搭建德州网架公司
  • 关键词网站排名查询互联网行业怎么赚钱
  • 集约化网站建设情况经验材料wordpress手机菜单导航
  • 下载百度2023最新版安装深圳网站建设seo推广优化
  • 做网站怎么租个域名flash如何做网页
  • 大同网站建设熊掌号wordpress退出登录界面
  • wordpress本地网站怎么访问淘宝联盟交钱建设网站
  • 济南手机建站哪家好电子商务网站建设 试卷