剑指 Offer II 024. 反转链表
创始人
2024-06-01 00:24:47

题目链接

剑指 Offer II 024. 反转链表 easy

题目描述

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

示例 1:

在这里插入图片描述

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

示例 2:

这里是引用

输入:head = [1,2]
输出:[2,1]

示例 3:

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

提示:

  • 链表中节点的数目范围是 [0,5000][0, 5000][0,5000]
  • −5000≤Node.val≤5000-5000 \leq Node.val \leq 5000−5000≤Node.val≤5000

分析:模拟

我们用 cur指向 当前结点 ,用 pre指向当前结点的 前驱节点 , 用 nextNode指向当前结点的 后继结点

在这里插入图片描述
cur的下一个结点指向 pre。接着再让 pre指向当前结点 cur,让cur指向 nextNode

在这里插入图片描述

一直这样操作,直到 cur指向 null此时的 pre指向的就是反转后的链表头节点,直接返回即可。

时间复杂度: O(n)O(n)O(n)

C++代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode *pre = nullptr , *cur = head;while(cur != nullptr){ListNode *nextNode = cur->next;cur->next = pre;pre = cur;cur = nextNode;}return pre;}
};

Python代码:

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def reverseList(self, head: ListNode) -> ListNode:pre , cur = None , headwhile cur != None:nextNode = cur.nextcur.next = prepre = curcur = nextNodereturn pre

相关内容

热门资讯

贝斯美(300796.SZ):... 格隆汇12月12日丨贝斯美(维权)(300796.SZ)公布,收到公司实际控制人陈峰先生通知,绍兴市...
美军人员利用军事邮件包裹走私冰... 据韩联社12日报道,韩国大法院(最高法院)日前对一名美军人员涉嫌违反毒品管理法一案作出终审判决,维持...
即将全面禁产!多个店铺卖断货,... 日前“水银体温计、血压计明年起禁产”的话题登上社交媒体热搜国家药监局明确通知: 自2026年1月...
劣迹网红“东北雨姐”“猫一杯”... 为进一步规范网络名人账号信息传播秩序,近期,北京市网信办启动“清朗京华·网络名人账号乱象整治”专项行...
合计约28亿元 两家A股公司同... 凭借着地理位置及劳动力等方面的优势,北非国家埃及正成为中国资本的投资沃土。12月12日晚,新凤鸣(6...