206.反转链表

206.反转链表

力扣题目链接(opens new window)

题意:反转一个单链表。

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

双双指针法:

创建三个节点 pre(反转时的第一个节点)、cur(当前指向需要反转的节点)、tem(cur反转操作前,需要暂存cur的下一个节点)

复制代码
   ListNode* reverseList(ListNode* head) {
       ListNode* pre=nullptr;
       ListNode* tem;
       ListNode* cur = head;
       while(cur!=nullptr){
           tem = cur->next;//暂存
           cur->next = pre;//反转
           pre = cur;//前一个节点移动至下一个
           cur = tem;//前一个节点移动至下一个
       }
       return cur;
   }
相关推荐
难得的我们12 小时前
单元测试在C++项目中的实践
开发语言·c++·算法
Once_day12 小时前
代码训练总结(1)算法和数据结构的框架思维
数据结构·算法
鹿角片ljp12 小时前
力扣125.验证回文串-双指针
数据结构·算法
We་ct12 小时前
LeetCode 30. 串联所有单词的子串:从暴力到高效,滑动窗口优化详解
前端·算法·leetcode·typescript
-Try hard-12 小时前
数据结构|概念及单向有头链表
数据结构·算法·vim
历程里程碑12 小时前
子串----和为K的子数组
大数据·python·算法·leetcode·elasticsearch·搜索引擎·哈希算法
Aaron158812 小时前
通信灵敏度计算与雷达灵敏度计算对比分析
网络·人工智能·深度学习·算法·fpga开发·信息与通信·信号处理
2301_7903009612 小时前
C++中的命令模式
开发语言·c++·算法
2301_8223769412 小时前
C++中的解释器模式
开发语言·c++·算法
xhbaitxl12 小时前
算法学习day31-贪心算法
学习·算法·贪心算法