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;
   }
相关推荐
爱学习的阿磊几秒前
自定义操作符重载指南
开发语言·c++·算法
zhuanggoahead18 分钟前
拓扑排序(Kahn算法)
网络·数据结构·c++·算法·排序算法
码农水水31 分钟前
SpringBoot配置优化:Tomcat+数据库+缓存+日志全场景教程
java·数据库·spring boot·后端·算法·tomcat·哈希算法
JMchen12332 分钟前
Android音频处理全解析:从3A算法到空间音频,打造专业级音频体验
android·经验分享·算法·kotlin·android studio·音视频
有一个好名字33 分钟前
力扣-省份数量
python·算法·leetcode
iAkuya38 分钟前
(leetcode)力扣100 55全排列
算法·leetcode·职场和发展
2301_7657031444 分钟前
动态库热加载技术
开发语言·c++·算法
2401_841495641 小时前
【强化学习】REINFORCE 算法
人工智能·python·算法·强化学习·reinforce·策略梯度·蒙特卡洛
棱镜Coding1 小时前
LeetCode-Hot100 30.两两交换链表中的节点
算法·leetcode·链表
2301_790300961 小时前
C++与量子计算模拟
开发语言·c++·算法