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

Leetcode_206.反转链表(递归)

在这里插入图片描述
这道题原本的方式是采用头插法来解决,现在有了一个新的思路,那就是递归

在设计递归时需要着重考虑的就是递归的终止条件,那么我们这个题的终止条件是什么呢?

在链表为空,或者链表为1个节点时,链表不需要反转,以此可以作为递归的终止条件,即:
head == nullptr || head->next == nullptr
结束条件有了,下来该写递归函数了。在没有达到终止条件时,应该反转链表,通过总体来看,当第一次反转时,应该反转 head->next 之后的链表,因为终止条件为 head == nullptr || head->next == nullptr,所以递归调用参数应该是 head->next,这样才能让递归逐步向链表尾部推进,直到触发终止条件。然后在回溯过程中,通过 head->next->next = head 来反转指针方向,完成整个链表的反转。

整个递归过程是从后向前的,在处理 1 节点是 , 链表已经变为了 5 -> 4 -> 3 -> 2 ->nullptr ,此时回溯就需要将2指向1 ,1指向nullptr,那么 2 这个节点的地址该如何获取呢?
可以在进行递归之前先获取这个节点的地址 ListNode * tail=head->next,由此获取节点2的地址,回到上面 就变为 1->next=tail->next(nullptr) ;2->next =1;,翻译一下也就是 head->next =tail->next; tail->next =head ;

ac代码:

/*** 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) {if(head==nullptr||head->next==nullptr) return head;ListNode *tail=head->next;ListNode * new_head=reverseList(head->next);head->next=tail->next;tail->next=head;return new_head;}
};
http://www.xdnf.cn/news/1428859.html

相关文章:

  • 【嵌入式电机控制#进阶7】V/F强拖启动
  • 变频器实习DAY41 单元测试介绍
  • 前端实现解析【导入】数据后调用批量处理接口
  • Redis有哪些部署方案?了解哨兵机制吗?
  • AI文档产品与传统OCR软件的根本区别是什么?
  • 手写Muduo网络库核心代码2--Poller、EPollPoller详细讲解
  • 百度智能云,除了AI还有啥?
  • 线程特定存储
  • Go语言开发合并文件小工具
  • go命令行工具:如何在现有的工程里加入使用cobra
  • 苹果手机文本转音频,自行制作背诵素材
  • Redis 持久化机制详解
  • 《WINDOWS 环境下32位汇编语言程序设计》第10章 内存管理和文件操作(2)
  • 文华财经wh6波段多空指标-变色K做多做空信号,抄底逃顶主图幅图
  • Docker启动两个Redis镜像并配置一主一从
  • Linux内核O(1)调度算法
  • 汽车制造工厂如何应用力控SCADA实现全方位智能监控与诊断
  • 从“成本中心”到“生产力引擎”:MCP如何将AI从“建议者”变为“执行者”
  • 2025年新版C语言 模电数电及51单片机Proteus嵌入式开发入门实战系统学习,一整套全齐了再也不用东拼西凑
  • 久等啦!Tigshop O2O多门店JAVA/PHP版本即将上线!
  • 通义万相Wan2.2-S2V-14B:AI视频生成的革命性突破与实践指南
  • c++ 类和对象(上)
  • 与后端对话:在React中优雅地请求API数据 (Fetch/Axios)
  • token存储方案
  • iOS XML 处理利器:CNXMLParser 与 CNXMLDocument 深度解析
  • 从零开始的python学习——函数(2)
  • 漫画短剧小程序系统开发:从0到1的核心架构与思路
  • 今天我们开始学习shell编程语言
  • @ZooKeeper 详细介绍部署与使用详细指南
  • 【JavaScript】前端两种路由模式,Hash路由,History 路由