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

dfs(十三)206. 反转链表

206. 反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1:

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?

 

先使用dfs访问到最后一个元素,然后用newhead保存新的头结点,最后使用head修改当前指针的后一个指针指向实现逆序操作。

/*** 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* newhead = reverseList(head->next);head->next->next = head; 进行逆置操作head->next = nullptr;  为了统一操作return newhead;  返回的是我们新建的newhead}};


http://www.mrgr.cn/news/94761.html

相关文章:

  • VLLM:虚拟大型语言模型(Virtual Large Language Model)
  • Hoppscotch 开源API 开发工具
  • Deepseek API+Python测试用例一键生成与导出-V1.0.2【实现需求文档图片识别与用例生成自动化】
  • 机器学习——深入浅出理解朴素贝叶斯算法
  • win10 c++ VsCode 配置PCL open3d并显示
  • Couldn‘t install PSEXESVC service: 拒绝访问。
  • Function 原型 原型链 继承的实现
  • Oracle检索数据
  • SpringBoot 启动过程
  • 蓝桥杯每日一题——Acwing 5438. 密接牛追踪2
  • 【大模型实战篇】使用GPTQ量化QwQ-32B微调后的推理模型
  • C++特性——智能指针
  • 【leetcode hot 100 146】LRU缓存
  • 玩转云服务器——阿里云操作系统控制台体验测评
  • Android开源库——RxJava和RxAndroid
  • Python条件语句
  • uniapp 多环境配置打包,比较优雅的解决方案,全网相对优解
  • 基于Springboot+服务器磁盘的本地文件存储方案
  • [项目]基于FreeRTOS的STM32四轴飞行器: 六.2.4g通信
  • 文档搜索引擎