当前位置: 首页 > 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.laogonggong.com/news/45143.html

相关文章:

  • 东莞网站推广推广软件关键词网站推广
  • 做网站 空间站长工具seo综合查询全面解析
  • 县政府网站网建设方案自媒体平台哪个收益高
  • 网站建设中服务器搭建方式关键词收录查询工具
  • wordpress文章首行缩进网站关键词优化方法
  • 网站开发做什么的美发培训职业学校
  • 其他公司盗用公司名做网站搜客
  • 网站的运营做网站的软件有哪些
  • 怎么在公司网站做超链接郑州网站优化培训
  • 网站设计公司石家庄品牌推广战略
  • 网站免费下载软件高端网站建设
  • 做秒杀网站友情链接教程
  • 台州路桥网站建设网站制作 网站建设
  • 设计素材网站排行榜前十名seo实战培训机构
  • 网站做百度百科的好处如何增加网站的外链
  • 网站充值怎么做分录就业seo好还是sem
  • 做网站引入字体网站如何注册
  • 做网站的计划电脑优化软件推荐
  • wordpress api 路径搜索引擎优化案例
  • 单页面网站国内有哪些百度网盘怎么提取别人资源
  • 长春做网站seo的软文推广的标准类型
  • 使用cn域名做网站的多吗域名访问网站入口
  • 新疆建设工程信息网电话重庆网站seo外包
  • wordpress.com 域名网站优化方案
  • 手机网站方案自己建网站需要多少钱
  • 西安知名的集团门户网站建设服务商百度推广网页版
  • 大学学风建设专题网站互联网营销专家
  • 动态电子商务网站建设报告免费推广神器
  • 做网站是要编程吗今天的国内新闻
  • vps被攻击网站打不开ping值高互联网营销的方式有哪些