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

Leetcode206.反转链表(HOT100)

链接:

我的代码:

class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode* p = head;ListNode*res = new ListNode(-1);while(p){ListNode*k = res->next;res->next = p;p = p->next;res->next->next = k;}return res->next;}
};

我用的是迭代实现。 

更好的代码: 

class Solution {
public:ListNode* reverseList(ListNode* head) {if(!head)return nullptr;ListNode* a = head,*b = head->next;while(b){ListNode*c = b->next;b->next = a;a = b;b = c;}head->next = nullptr;return a;}
};

第一步:

第二步:
 

最后一步:
 

此时,别忘了,head仍然指向原来的头结点,这个头结点现在是尾节点了,所以把它的next置空。

 更好的代码(递归实现):

class Solution {
public:ListNode* reverseList(ListNode* head) {if(!head||!head->next)return head;auto tail = reverseList(head->next);head->next->next = head;head->next = nullptr;return tail;}
};

 图示:

 

 

上图是head->next->next = head;

完毕。 

 

 

http://www.lryc.cn/news/488083.html

相关文章:

  • 怎么做好白盒测试?
  • 【神经网络基础】
  • 实战 | C#中使用YoloV8和OpenCvSharp实现目标检测 (步骤 + 源码)
  • debian 如何进入root
  • 短视频矩阵系统:智能批量剪辑、账号管理新纪元!
  • 【SpringMVC - 1】基本介绍+快速入门+图文解析SpringMVC执行流程
  • vitepress博客模板搭建
  • Git入门图文教程 -- 深入浅出 ( 保姆级 )
  • Linux编辑器 - vim
  • Spring Security使用基本认证(Basic Auth)保护REST API
  • MySQL —— explain 查看执行计划与 MySQL 优化
  • 出海第一步:搞定业务系统的多区域部署
  • 二手手机回收小程序,一键便捷高效回收
  • 开源模型应用落地-Qwen2.5-7B-Instruct与vllm实现离线推理-性能分析(四)
  • 深入解析小程序组件:view 和 scroll-view 的基本用法
  • 【汇编语言】转移指令的原理(三) —— 汇编跳转指南:jcxz、loop与位移的深度解读
  • opencv-python 分离边缘粘连的物体(距离变换)
  • 机器学习杂笔记1:类型-数据集-效果评估-sklearn-机器学习算法分类
  • Django+Nginx+uwsgi网站使用Channels+redis+daphne实现简单的多人在线聊天及消息存储功能
  • 数据结构在二叉树Oj中利用子问题思路来解决问题
  • 华为openEuler考试真题演练(附答案)
  • 生成自签名证书并配置 HTTPS 使用自签名证书
  • 物联网核心安全系列——智能汽车安全防护的重要性
  • 数据库视图
  • 从传统分析到智能问数,打造零门槛数据分析方案
  • java 设计模式 模板方法模式
  • 基于UDP和TCP实现回显服务器
  • 在 CentOS 系统上直接安装 MongoDB 4.0.25
  • Android和IOS的区别
  • 数据库基础(MySQL)