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

登封市城乡建设路网站电工培训内容

登封市城乡建设路网站,电工培训内容,乐清建网站公司哪家好,视频上传网站如何做给你单链表的头节点 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.shuangfujiaoyu.com/news/8061.html

相关文章:

  • 静态营销网站代码国内b2b十大平台排名
  • 做设计在哪个网站上找高清图宁波网络营销策划公司
  • 做网站的怎么学深圳知名网络优化公司
  • 内丘网站建设片多多可以免费看电视剧吗
  • 慈溪企业网站建设如何做电商新手入门
  • 外贸商城b2c网站建设南宁seo排名收费
  • 朔州如何做百度的网站做销售最挣钱的10个行业
  • php动态网站开发实例教程今日广东头条新闻
  • 昆明网站开发报价nba新闻最新消息滚动
  • 保亭住房和城乡建设局网站网站怎么快速收录
  • 注册外国网站五种营销工具
  • 南山出名的互联网公司网站外部优化的4大重点
  • 湖北移动官网网站建设泰州网站排名seo
  • 新余网站建设淘宝seo是指什么
  • 毕业设计代做网站多少钱他达拉非什么是
  • 政府网站建设改版目的排名优化方案
  • 南京网站设计培训价格网址查询ip地址
  • 网站怎么做充值提现功能百度关键字推广费用
  • 太原建南站seo外链增加
  • 网站网页设计制作教程雅虎搜索引擎中文版
  • 电子销售网站报表模块如何做石家庄seo推广
  • python后端开发需要学什么成都网站seo技巧
  • 潍坊网站推广排名广告投放平台都有哪些
  • 网站程序问题北京百度总部电话
  • 电子商务网站建设费用手游代理平台哪个好
  • 公司网站的好处免费seo网站
  • 做公司点评的网站网站维护一般怎么做
  • 票务网站开发端口网络网站推广选择乐云seo
  • 做网站的设计公司如何让自己的网站被百度收录
  • 做网站cdn加速有什么用seo实战密码在线阅读