当前位置: 首页 > 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.dtcms.com/a/362627.html

相关文章:

  • 学习日记-SpringMVC-day48-9.2
  • JS 秒转换成 MM:SS 格式
  • leetcode算法刷题的第二十四天
  • 破解数字化困局:五层双闭环治理模型详解
  • AV1 HEADERS详解
  • Linux - 进程切换 进程调渡
  • Redis 持久化机制详解
  • GD32入门到实战27--传感器任务框架搭建
  • 域内横向移动
  • AI 生成视频入门:用 Pika Labs+Runway ML 制作短内容
  • C++ numeric库简介与使用指南
  • 【LeetCode】1792. 最大平均通过率(康复-T1)
  • 校企合作| 长春大学旅游学院副董事长张海涛率队到访卓翼智能,共绘无人机技术赋能“AI+文旅”发展新蓝图
  • DAG与云计算任务调度优化
  • 【android bluetooth 协议分析 21】【ble 介绍 3】【ble acl Supervision Timeout 介绍】
  • 无人机系统理论基础(有课件)
  • 无人机小尺寸RFSOC ZU47DR板卡
  • 无人机传感器技术要点与难点解析
  • 【无人机三维路径规划】基于遗传算法GA结合粒子群算法PSO无人机复杂环境避障三维路径规划(含GA和PSO对比)研究
  • 基于YOLOv4的无人机视觉手势识别系统:从原理到实践
  • C++面试题
  • 股指期货是股市下跌的原罪,还是风险对冲好帮手?
  • 什么是 DNSSEC?
  • 面试tips--MySQLRedis--Redis 有序集合用跳表不用B+树 MySQL用B+树作为存储引擎不用跳表:原因如下
  • 278-基于Django的协同过滤旅游推荐系统
  • 详解Grafana k6 的阈值(Thresholds)
  • os.path:平台独立的文件名管理
  • sql执行过程
  • Tomcat 全面指南:从目录结构到应用部署与高级配置
  • Java-Spring入门指南(一)Spring简介