【剑指offer--C/C++】JZ24 反转链表

一、题目


二、解决方案1--添加指针辅助遍历

思路:

三个指针,分别指向:当前节点、前一个节点、后一个节点。通过指针的辅助使得当前节点的next指向前一个节点,这样遍历完一遍之后所有的next全部翻转指向其前一个节点。

代码:

cpp 复制代码
/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    ListNode* ReverseList(ListNode* head) {
        // write code here

       //链表本身没有元素或只有一个元素
       if(head==NULL || head->next==NULL){
        return head;
       }
   
     ListNode *preNode=NULL;           //前一个节点
     ListNode *nextNode;    //后一个节点
     while(head){
        nextNode= head->next;
        head->next=preNode;
        preNode=head;
        head=nextNode;

     }
     return preNode;
        
    }
};

三、解决方案二--使用栈进行辅助

思路:

遍历一轮,将节点依次压入栈,然后从栈顶依次取出节点,并另上一次取出节点的next指向当前取出的节点,最后记得将最后一个节点的nxet指向NULL。

题目:

cpp 复制代码
/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    ListNode* ReverseList(ListNode* head) {
        // write code here

       //链表本身没有元素或只有一个元素
       if(head==NULL || head->next==NULL){
        return head;
       }
      
       std::stack<ListNode *> s;
        while(head){
            s.push(head);
            head=head->next;
        }
        cout<<s.size()<<endl;
        ListNode *newHead;
        head=s.top();
        s.pop();
        newHead=head;

        while(!s.empty()){
            head->next=s.top();
            s.pop();
            head=head->next;

        }
        //最后一个元素的next指向空,不然就变成循环链表了
        head->next=NULL;   
        return newHead;
        
    }
};
相关推荐
syagain_zsx7 分钟前
STL 之 vector 讲练结合
c++·算法
十月的皮皮20 分钟前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
牛油果子哥q36 分钟前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
奇妙方程式1 小时前
2026年第九届GXCPC广西大学生程序设计大赛(热身赛)题解
c++·编程比赛·编程竞赛·gxcpc
Tian_Hang2 小时前
C++原型模式(Protype)
开发语言·c++·算法
FL16238631293 小时前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv
玖玥拾3 小时前
C/C++ 数据结构(六)链表迭代器与底层
c语言·数据结构·c++·链表·stl库
牛油果子哥q3 小时前
AVL平衡树与红黑树深度精讲对比,平衡因子、四大旋转原理、着色规则、平衡策略、性能差异与面试手撕全解
数据结构·c++·面试
汉克老师4 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利
C++ 老炮儿的技术栈4 小时前
Ubuntu root账号自动登陆
linux·运维·服务器·c语言·c++·ubuntu·visual studio