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

35.反转链表

定义一个函数,输入一个链表的头结点,反转该链表并输出反转后链表的头结点。

思考题:

  • 请同时实现迭代版本和递归版本。
数据范围

链表长度 [0,30]。

样例
输入:1->2->3->4->5->NULL

输出:5->4->3->2->1->NULL

 1.迭代操作

ListNode* reverseList(ListNode* head) {
        ListNode *prev=nullptr;
        ListNode *cur=head;
        while(cur){
            ListNode *next=cur->next;
            cur->next=prev;
            prev=cur;
            cur=next;
        }
        return prev;
    }

2递归操作

ListNode* reverseList(ListNode* head) {
        if(!head||!head->next)return head;
        ListNode *tail=reverseList(head->next);
        head->next->next=head;
        head->next=nullptr;
        return tail;
    }


http://www.kler.cn/news/343415.html

相关文章:

  • python 实现bfs 最短路径算法
  • python中的数组模块numpy(一)(适用物联网数据可视化及数据分析)
  • 【VUE】defineProperty和proxy的区别
  • 股市和期市历史分钟以及均线策略高级用法
  • 1.GoLang概述开发环境
  • 杂谈--Linux是什么用途?
  • 【java应用系统连接自有https证书(无法验证)的minio服务时报错问题处理过程】
  • JAVA中线程的生命周期
  • 将JSON的格式数据存储到数据库中
  • Jetpack Compose 页面跳转 - 导航Navigation使用和封装
  • 共识算法Raft
  • 【新书】使用生成式人工智能和Python开始数据分析
  • 回归涉及的函数
  • C语言-了解程序环境和预处理看这一篇(超详解)
  • std::future::then的概念和使用方法
  • Java SSL使用Openssl ECC加密生成证书遇到的坑
  • Python和C++及MATLAB低温磁态机器学习模型
  • 【解决办法】git clone报错unable to access ‘xxx‘: SSL certificate problem
  • 第19周JavaWeb编程实战-MyBatis实现OA系统 面试题解析
  • Go语言学习代码记录