【剑指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;
        
    }
};
相关推荐
六bring个六1 分钟前
文件系统交互实现
开发语言·c++·qt·交互
小山菌16 分钟前
mac中加载C++动态库文件
开发语言·c++·macos
疯狂学习GIS23 分钟前
Windows配置VS Code详细流程
c++·学术工作效率
__BMGT()24 分钟前
C++ QT图片查看器
前端·c++·qt
Echo``41 分钟前
1:OpenCV—图像基础
c++·图像处理·人工智能·opencv·算法·计算机视觉·视觉检测
ALex_zry1 小时前
Ubuntu 20.04 C++开发环境搭建指南(2025版)
linux·c++·ubuntu
_F_y3 小时前
list简单模拟实现
c++·list
前进的程序员3 小时前
C++ 在 Windows 和 Linux 平台上的开发差异及常见问题
linux·c++·windows
努力写代码的熊大4 小时前
链表的中间结点数据结构oj题(力扣876)
数据结构·leetcode·链表
daiwoliyunshang4 小时前
哈希表实现(1):
数据结构·c++